primary-api-models 0.1.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 (1580) hide show
  1. primary_api_models/__init__.py +53 -0
  2. primary_api_models/account_data.py +62 -0
  3. primary_api_models/commons.py +49 -0
  4. primary_api_models/detailed_instruments.py +11 -0
  5. primary_api_models/detailed_position.py +53 -0
  6. primary_api_models/enhanced_models.py +27 -0
  7. primary_api_models/enums.py +184 -0
  8. primary_api_models/instrument_details.py +48 -0
  9. primary_api_models/listed_instruments.py +14 -0
  10. primary_api_models/market_data.py +25 -0
  11. primary_api_models/order_report.py +34 -0
  12. primary_api_models/order_status.py +11 -0
  13. primary_api_models/positions.py +27 -0
  14. primary_api_models-0.1.0.dist-info/METADATA +7 -0
  15. primary_api_models-0.1.0.dist-info/RECORD +1580 -0
  16. primary_api_models-0.1.0.dist-info/WHEEL +5 -0
  17. primary_api_models-0.1.0.dist-info/top_level.txt +3 -0
  18. tests/conftest.py +6 -0
  19. tests/test_models.py +61 -0
  20. venv/Lib/site-packages/_pytest/__init__.py +13 -0
  21. venv/Lib/site-packages/_pytest/_argcomplete.py +117 -0
  22. venv/Lib/site-packages/_pytest/_code/__init__.py +26 -0
  23. venv/Lib/site-packages/_pytest/_code/code.py +1571 -0
  24. venv/Lib/site-packages/_pytest/_code/source.py +225 -0
  25. venv/Lib/site-packages/_pytest/_io/__init__.py +10 -0
  26. venv/Lib/site-packages/_pytest/_io/pprint.py +673 -0
  27. venv/Lib/site-packages/_pytest/_io/saferepr.py +130 -0
  28. venv/Lib/site-packages/_pytest/_io/terminalwriter.py +258 -0
  29. venv/Lib/site-packages/_pytest/_io/wcwidth.py +57 -0
  30. venv/Lib/site-packages/_pytest/_py/__init__.py +0 -0
  31. venv/Lib/site-packages/_pytest/_py/error.py +119 -0
  32. venv/Lib/site-packages/_pytest/_py/path.py +1475 -0
  33. venv/Lib/site-packages/_pytest/_version.py +24 -0
  34. venv/Lib/site-packages/_pytest/assertion/__init__.py +208 -0
  35. venv/Lib/site-packages/_pytest/assertion/rewrite.py +1202 -0
  36. venv/Lib/site-packages/_pytest/assertion/truncate.py +137 -0
  37. venv/Lib/site-packages/_pytest/assertion/util.py +615 -0
  38. venv/Lib/site-packages/_pytest/cacheprovider.py +646 -0
  39. venv/Lib/site-packages/_pytest/capture.py +1144 -0
  40. venv/Lib/site-packages/_pytest/compat.py +314 -0
  41. venv/Lib/site-packages/_pytest/config/__init__.py +2203 -0
  42. venv/Lib/site-packages/_pytest/config/argparsing.py +578 -0
  43. venv/Lib/site-packages/_pytest/config/compat.py +85 -0
  44. venv/Lib/site-packages/_pytest/config/exceptions.py +15 -0
  45. venv/Lib/site-packages/_pytest/config/findpaths.py +350 -0
  46. venv/Lib/site-packages/_pytest/debugging.py +407 -0
  47. venv/Lib/site-packages/_pytest/deprecated.py +99 -0
  48. venv/Lib/site-packages/_pytest/doctest.py +736 -0
  49. venv/Lib/site-packages/_pytest/faulthandler.py +119 -0
  50. venv/Lib/site-packages/_pytest/fixtures.py +2047 -0
  51. venv/Lib/site-packages/_pytest/freeze_support.py +45 -0
  52. venv/Lib/site-packages/_pytest/helpconfig.py +293 -0
  53. venv/Lib/site-packages/_pytest/hookspec.py +1342 -0
  54. venv/Lib/site-packages/_pytest/junitxml.py +695 -0
  55. venv/Lib/site-packages/_pytest/legacypath.py +468 -0
  56. venv/Lib/site-packages/_pytest/logging.py +960 -0
  57. venv/Lib/site-packages/_pytest/main.py +1203 -0
  58. venv/Lib/site-packages/_pytest/mark/__init__.py +301 -0
  59. venv/Lib/site-packages/_pytest/mark/expression.py +353 -0
  60. venv/Lib/site-packages/_pytest/mark/structures.py +664 -0
  61. venv/Lib/site-packages/_pytest/monkeypatch.py +435 -0
  62. venv/Lib/site-packages/_pytest/nodes.py +772 -0
  63. venv/Lib/site-packages/_pytest/outcomes.py +308 -0
  64. venv/Lib/site-packages/_pytest/pastebin.py +117 -0
  65. venv/Lib/site-packages/_pytest/pathlib.py +1063 -0
  66. venv/Lib/site-packages/_pytest/py.typed +0 -0
  67. venv/Lib/site-packages/_pytest/pytester.py +1791 -0
  68. venv/Lib/site-packages/_pytest/pytester_assertions.py +74 -0
  69. venv/Lib/site-packages/_pytest/python.py +1772 -0
  70. venv/Lib/site-packages/_pytest/python_api.py +819 -0
  71. venv/Lib/site-packages/_pytest/raises.py +1517 -0
  72. venv/Lib/site-packages/_pytest/recwarn.py +367 -0
  73. venv/Lib/site-packages/_pytest/reports.py +694 -0
  74. venv/Lib/site-packages/_pytest/runner.py +580 -0
  75. venv/Lib/site-packages/_pytest/scope.py +91 -0
  76. venv/Lib/site-packages/_pytest/setuponly.py +98 -0
  77. venv/Lib/site-packages/_pytest/setupplan.py +39 -0
  78. venv/Lib/site-packages/_pytest/skipping.py +321 -0
  79. venv/Lib/site-packages/_pytest/stash.py +116 -0
  80. venv/Lib/site-packages/_pytest/stepwise.py +209 -0
  81. venv/Lib/site-packages/_pytest/subtests.py +411 -0
  82. venv/Lib/site-packages/_pytest/terminal.py +1763 -0
  83. venv/Lib/site-packages/_pytest/terminalprogress.py +30 -0
  84. venv/Lib/site-packages/_pytest/threadexception.py +152 -0
  85. venv/Lib/site-packages/_pytest/timing.py +95 -0
  86. venv/Lib/site-packages/_pytest/tmpdir.py +337 -0
  87. venv/Lib/site-packages/_pytest/tracemalloc.py +24 -0
  88. venv/Lib/site-packages/_pytest/unittest.py +632 -0
  89. venv/Lib/site-packages/_pytest/unraisableexception.py +163 -0
  90. venv/Lib/site-packages/_pytest/warning_types.py +172 -0
  91. venv/Lib/site-packages/_pytest/warnings.py +151 -0
  92. venv/Lib/site-packages/annotated_types/__init__.py +432 -0
  93. venv/Lib/site-packages/annotated_types/py.typed +0 -0
  94. venv/Lib/site-packages/annotated_types/test_cases.py +151 -0
  95. venv/Lib/site-packages/build/__init__.py +47 -0
  96. venv/Lib/site-packages/build/__main__.py +654 -0
  97. venv/Lib/site-packages/build/_builder.py +393 -0
  98. venv/Lib/site-packages/build/_compat/__init__.py +0 -0
  99. venv/Lib/site-packages/build/_compat/importlib.py +22 -0
  100. venv/Lib/site-packages/build/_compat/tarfile.py +31 -0
  101. venv/Lib/site-packages/build/_compat/tomllib.py +19 -0
  102. venv/Lib/site-packages/build/_ctx.py +105 -0
  103. venv/Lib/site-packages/build/_exceptions.py +69 -0
  104. venv/Lib/site-packages/build/_types.py +22 -0
  105. venv/Lib/site-packages/build/_util.py +68 -0
  106. venv/Lib/site-packages/build/env.py +507 -0
  107. venv/Lib/site-packages/build/py.typed +0 -0
  108. venv/Lib/site-packages/build/util.py +70 -0
  109. venv/Lib/site-packages/certifi/__init__.py +4 -0
  110. venv/Lib/site-packages/certifi/__main__.py +12 -0
  111. venv/Lib/site-packages/certifi/core.py +83 -0
  112. venv/Lib/site-packages/certifi/py.typed +0 -0
  113. venv/Lib/site-packages/charset_normalizer/__init__.py +48 -0
  114. venv/Lib/site-packages/charset_normalizer/__main__.py +6 -0
  115. venv/Lib/site-packages/charset_normalizer/api.py +988 -0
  116. venv/Lib/site-packages/charset_normalizer/cd.py +454 -0
  117. venv/Lib/site-packages/charset_normalizer/cli/__init__.py +8 -0
  118. venv/Lib/site-packages/charset_normalizer/cli/__main__.py +362 -0
  119. venv/Lib/site-packages/charset_normalizer/constant.py +2050 -0
  120. venv/Lib/site-packages/charset_normalizer/legacy.py +79 -0
  121. venv/Lib/site-packages/charset_normalizer/md.py +936 -0
  122. venv/Lib/site-packages/charset_normalizer/models.py +369 -0
  123. venv/Lib/site-packages/charset_normalizer/py.typed +0 -0
  124. venv/Lib/site-packages/charset_normalizer/utils.py +422 -0
  125. venv/Lib/site-packages/charset_normalizer/version.py +8 -0
  126. venv/Lib/site-packages/colorama/__init__.py +7 -0
  127. venv/Lib/site-packages/colorama/ansi.py +102 -0
  128. venv/Lib/site-packages/colorama/ansitowin32.py +277 -0
  129. venv/Lib/site-packages/colorama/initialise.py +121 -0
  130. venv/Lib/site-packages/colorama/tests/__init__.py +1 -0
  131. venv/Lib/site-packages/colorama/tests/ansi_test.py +76 -0
  132. venv/Lib/site-packages/colorama/tests/ansitowin32_test.py +294 -0
  133. venv/Lib/site-packages/colorama/tests/initialise_test.py +189 -0
  134. venv/Lib/site-packages/colorama/tests/isatty_test.py +57 -0
  135. venv/Lib/site-packages/colorama/tests/utils.py +49 -0
  136. venv/Lib/site-packages/colorama/tests/winterm_test.py +131 -0
  137. venv/Lib/site-packages/colorama/win32.py +180 -0
  138. venv/Lib/site-packages/colorama/winterm.py +195 -0
  139. venv/Lib/site-packages/docutils/__init__.py +341 -0
  140. venv/Lib/site-packages/docutils/__main__.py +103 -0
  141. venv/Lib/site-packages/docutils/core.py +855 -0
  142. venv/Lib/site-packages/docutils/examples.py +123 -0
  143. venv/Lib/site-packages/docutils/frontend.py +1178 -0
  144. venv/Lib/site-packages/docutils/io.py +716 -0
  145. venv/Lib/site-packages/docutils/languages/__init__.py +117 -0
  146. venv/Lib/site-packages/docutils/languages/af.py +58 -0
  147. venv/Lib/site-packages/docutils/languages/ar.py +60 -0
  148. venv/Lib/site-packages/docutils/languages/ca.py +65 -0
  149. venv/Lib/site-packages/docutils/languages/cs.py +60 -0
  150. venv/Lib/site-packages/docutils/languages/da.py +61 -0
  151. venv/Lib/site-packages/docutils/languages/de.py +58 -0
  152. venv/Lib/site-packages/docutils/languages/en.py +60 -0
  153. venv/Lib/site-packages/docutils/languages/eo.py +61 -0
  154. venv/Lib/site-packages/docutils/languages/es.py +58 -0
  155. venv/Lib/site-packages/docutils/languages/fa.py +60 -0
  156. venv/Lib/site-packages/docutils/languages/fi.py +60 -0
  157. venv/Lib/site-packages/docutils/languages/fr.py +58 -0
  158. venv/Lib/site-packages/docutils/languages/gl.py +62 -0
  159. venv/Lib/site-packages/docutils/languages/he.py +62 -0
  160. venv/Lib/site-packages/docutils/languages/it.py +58 -0
  161. venv/Lib/site-packages/docutils/languages/ja.py +60 -0
  162. venv/Lib/site-packages/docutils/languages/ka.py +58 -0
  163. venv/Lib/site-packages/docutils/languages/ko.py +60 -0
  164. venv/Lib/site-packages/docutils/languages/lt.py +60 -0
  165. venv/Lib/site-packages/docutils/languages/lv.py +59 -0
  166. venv/Lib/site-packages/docutils/languages/nl.py +60 -0
  167. venv/Lib/site-packages/docutils/languages/pl.py +60 -0
  168. venv/Lib/site-packages/docutils/languages/pt_br.py +60 -0
  169. venv/Lib/site-packages/docutils/languages/ru.py +58 -0
  170. venv/Lib/site-packages/docutils/languages/sk.py +58 -0
  171. venv/Lib/site-packages/docutils/languages/sv.py +59 -0
  172. venv/Lib/site-packages/docutils/languages/uk.py +58 -0
  173. venv/Lib/site-packages/docutils/languages/zh_cn.py +62 -0
  174. venv/Lib/site-packages/docutils/languages/zh_tw.py +61 -0
  175. venv/Lib/site-packages/docutils/nodes.py +3341 -0
  176. venv/Lib/site-packages/docutils/parsers/__init__.py +115 -0
  177. venv/Lib/site-packages/docutils/parsers/commonmark_wrapper.py +56 -0
  178. venv/Lib/site-packages/docutils/parsers/docutils_xml.py +194 -0
  179. venv/Lib/site-packages/docutils/parsers/null.py +24 -0
  180. venv/Lib/site-packages/docutils/parsers/recommonmark_wrapper.py +174 -0
  181. venv/Lib/site-packages/docutils/parsers/rst/__init__.py +414 -0
  182. venv/Lib/site-packages/docutils/parsers/rst/directives/__init__.py +480 -0
  183. venv/Lib/site-packages/docutils/parsers/rst/directives/admonitions.py +101 -0
  184. venv/Lib/site-packages/docutils/parsers/rst/directives/body.py +329 -0
  185. venv/Lib/site-packages/docutils/parsers/rst/directives/html.py +21 -0
  186. venv/Lib/site-packages/docutils/parsers/rst/directives/images.py +186 -0
  187. venv/Lib/site-packages/docutils/parsers/rst/directives/misc.py +690 -0
  188. venv/Lib/site-packages/docutils/parsers/rst/directives/parts.py +129 -0
  189. venv/Lib/site-packages/docutils/parsers/rst/directives/references.py +28 -0
  190. venv/Lib/site-packages/docutils/parsers/rst/directives/tables.py +523 -0
  191. venv/Lib/site-packages/docutils/parsers/rst/languages/__init__.py +63 -0
  192. venv/Lib/site-packages/docutils/parsers/rst/languages/af.py +107 -0
  193. venv/Lib/site-packages/docutils/parsers/rst/languages/ar.py +99 -0
  194. venv/Lib/site-packages/docutils/parsers/rst/languages/ca.py +130 -0
  195. venv/Lib/site-packages/docutils/parsers/rst/languages/cs.py +110 -0
  196. venv/Lib/site-packages/docutils/parsers/rst/languages/da.py +113 -0
  197. venv/Lib/site-packages/docutils/parsers/rst/languages/de.py +106 -0
  198. venv/Lib/site-packages/docutils/parsers/rst/languages/en.py +115 -0
  199. venv/Lib/site-packages/docutils/parsers/rst/languages/eo.py +118 -0
  200. venv/Lib/site-packages/docutils/parsers/rst/languages/es.py +121 -0
  201. venv/Lib/site-packages/docutils/parsers/rst/languages/fa.py +102 -0
  202. venv/Lib/site-packages/docutils/parsers/rst/languages/fi.py +98 -0
  203. venv/Lib/site-packages/docutils/parsers/rst/languages/fr.py +107 -0
  204. venv/Lib/site-packages/docutils/parsers/rst/languages/gl.py +106 -0
  205. venv/Lib/site-packages/docutils/parsers/rst/languages/he.py +110 -0
  206. venv/Lib/site-packages/docutils/parsers/rst/languages/it.py +98 -0
  207. venv/Lib/site-packages/docutils/parsers/rst/languages/ja.py +119 -0
  208. venv/Lib/site-packages/docutils/parsers/rst/languages/ka.py +89 -0
  209. venv/Lib/site-packages/docutils/parsers/rst/languages/ko.py +111 -0
  210. venv/Lib/site-packages/docutils/parsers/rst/languages/lt.py +109 -0
  211. venv/Lib/site-packages/docutils/parsers/rst/languages/lv.py +108 -0
  212. venv/Lib/site-packages/docutils/parsers/rst/languages/nl.py +113 -0
  213. venv/Lib/site-packages/docutils/parsers/rst/languages/pl.py +100 -0
  214. venv/Lib/site-packages/docutils/parsers/rst/languages/pt_br.py +109 -0
  215. venv/Lib/site-packages/docutils/parsers/rst/languages/ru.py +90 -0
  216. venv/Lib/site-packages/docutils/parsers/rst/languages/sk.py +96 -0
  217. venv/Lib/site-packages/docutils/parsers/rst/languages/sv.py +96 -0
  218. venv/Lib/site-packages/docutils/parsers/rst/languages/uk.py +91 -0
  219. venv/Lib/site-packages/docutils/parsers/rst/languages/zh_cn.py +104 -0
  220. venv/Lib/site-packages/docutils/parsers/rst/languages/zh_tw.py +109 -0
  221. venv/Lib/site-packages/docutils/parsers/rst/roles.py +450 -0
  222. venv/Lib/site-packages/docutils/parsers/rst/states.py +3266 -0
  223. venv/Lib/site-packages/docutils/parsers/rst/tableparser.py +543 -0
  224. venv/Lib/site-packages/docutils/readers/__init__.py +135 -0
  225. venv/Lib/site-packages/docutils/readers/doctree.py +50 -0
  226. venv/Lib/site-packages/docutils/readers/pep.py +55 -0
  227. venv/Lib/site-packages/docutils/readers/standalone.py +65 -0
  228. venv/Lib/site-packages/docutils/statemachine.py +1534 -0
  229. venv/Lib/site-packages/docutils/transforms/__init__.py +196 -0
  230. venv/Lib/site-packages/docutils/transforms/components.py +56 -0
  231. venv/Lib/site-packages/docutils/transforms/frontmatter.py +548 -0
  232. venv/Lib/site-packages/docutils/transforms/misc.py +143 -0
  233. venv/Lib/site-packages/docutils/transforms/parts.py +175 -0
  234. venv/Lib/site-packages/docutils/transforms/peps.py +315 -0
  235. venv/Lib/site-packages/docutils/transforms/references.py +990 -0
  236. venv/Lib/site-packages/docutils/transforms/universal.py +364 -0
  237. venv/Lib/site-packages/docutils/transforms/writer_aux.py +57 -0
  238. venv/Lib/site-packages/docutils/utils/__init__.py +850 -0
  239. venv/Lib/site-packages/docutils/utils/_roman_numerals.py +264 -0
  240. venv/Lib/site-packages/docutils/utils/_typing.py +39 -0
  241. venv/Lib/site-packages/docutils/utils/code_analyzer.py +140 -0
  242. venv/Lib/site-packages/docutils/utils/math/__init__.py +77 -0
  243. venv/Lib/site-packages/docutils/utils/math/latex2mathml.py +1252 -0
  244. venv/Lib/site-packages/docutils/utils/math/math2html.py +3166 -0
  245. venv/Lib/site-packages/docutils/utils/math/mathalphabet2unichar.py +892 -0
  246. venv/Lib/site-packages/docutils/utils/math/mathml_elements.py +482 -0
  247. venv/Lib/site-packages/docutils/utils/math/tex2mathml_extern.py +263 -0
  248. venv/Lib/site-packages/docutils/utils/math/tex2unichar.py +730 -0
  249. venv/Lib/site-packages/docutils/utils/math/unichar2tex.py +808 -0
  250. venv/Lib/site-packages/docutils/utils/punctuation_chars.py +123 -0
  251. venv/Lib/site-packages/docutils/utils/smartquotes.py +1006 -0
  252. venv/Lib/site-packages/docutils/utils/urischemes.py +138 -0
  253. venv/Lib/site-packages/docutils/writers/__init__.py +277 -0
  254. venv/Lib/site-packages/docutils/writers/_html_base.py +1895 -0
  255. venv/Lib/site-packages/docutils/writers/docutils_xml.py +191 -0
  256. venv/Lib/site-packages/docutils/writers/html4css1/__init__.py +964 -0
  257. venv/Lib/site-packages/docutils/writers/html5_polyglot/__init__.py +398 -0
  258. venv/Lib/site-packages/docutils/writers/latex2e/__init__.py +3417 -0
  259. venv/Lib/site-packages/docutils/writers/manpage.py +1353 -0
  260. venv/Lib/site-packages/docutils/writers/null.py +28 -0
  261. venv/Lib/site-packages/docutils/writers/odf_odt/__init__.py +3461 -0
  262. venv/Lib/site-packages/docutils/writers/odf_odt/prepstyles.py +80 -0
  263. venv/Lib/site-packages/docutils/writers/odf_odt/pygmentsformatter.py +106 -0
  264. venv/Lib/site-packages/docutils/writers/pep_html/__init__.py +102 -0
  265. venv/Lib/site-packages/docutils/writers/pseudoxml.py +41 -0
  266. venv/Lib/site-packages/docutils/writers/s5_html/__init__.py +354 -0
  267. venv/Lib/site-packages/docutils/writers/xetex/__init__.py +168 -0
  268. venv/Lib/site-packages/id/__init__.py +114 -0
  269. venv/Lib/site-packages/id/__main__.py +88 -0
  270. venv/Lib/site-packages/id/_internal/oidc/__init__.py +13 -0
  271. venv/Lib/site-packages/id/_internal/oidc/ambient.py +363 -0
  272. venv/Lib/site-packages/id/py.typed +4 -0
  273. venv/Lib/site-packages/idna/__init__.py +45 -0
  274. venv/Lib/site-packages/idna/codec.py +122 -0
  275. venv/Lib/site-packages/idna/compat.py +15 -0
  276. venv/Lib/site-packages/idna/core.py +440 -0
  277. venv/Lib/site-packages/idna/idnadata.py +4367 -0
  278. venv/Lib/site-packages/idna/intranges.py +57 -0
  279. venv/Lib/site-packages/idna/package_data.py +1 -0
  280. venv/Lib/site-packages/idna/py.typed +0 -0
  281. venv/Lib/site-packages/idna/uts46data.py +8384 -0
  282. venv/Lib/site-packages/iniconfig/__init__.py +249 -0
  283. venv/Lib/site-packages/iniconfig/_parse.py +163 -0
  284. venv/Lib/site-packages/iniconfig/_version.py +34 -0
  285. venv/Lib/site-packages/iniconfig/exceptions.py +16 -0
  286. venv/Lib/site-packages/iniconfig/py.typed +0 -0
  287. venv/Lib/site-packages/jaraco/classes/__init__.py +0 -0
  288. venv/Lib/site-packages/jaraco/classes/ancestry.py +76 -0
  289. venv/Lib/site-packages/jaraco/classes/meta.py +85 -0
  290. venv/Lib/site-packages/jaraco/classes/properties.py +241 -0
  291. venv/Lib/site-packages/jaraco/classes/py.typed +0 -0
  292. venv/Lib/site-packages/jaraco/context/__init__.py +422 -0
  293. venv/Lib/site-packages/jaraco/context/py.typed +0 -0
  294. venv/Lib/site-packages/jaraco/functools/__init__.py +722 -0
  295. venv/Lib/site-packages/jaraco/functools/__init__.pyi +123 -0
  296. venv/Lib/site-packages/jaraco/functools/py.typed +0 -0
  297. venv/Lib/site-packages/keyring/__init__.py +17 -0
  298. venv/Lib/site-packages/keyring/__main__.py +4 -0
  299. venv/Lib/site-packages/keyring/backend.py +300 -0
  300. venv/Lib/site-packages/keyring/backends/SecretService.py +120 -0
  301. venv/Lib/site-packages/keyring/backends/Windows.py +168 -0
  302. venv/Lib/site-packages/keyring/backends/__init__.py +0 -0
  303. venv/Lib/site-packages/keyring/backends/chainer.py +71 -0
  304. venv/Lib/site-packages/keyring/backends/fail.py +30 -0
  305. venv/Lib/site-packages/keyring/backends/kwallet.py +164 -0
  306. venv/Lib/site-packages/keyring/backends/libsecret.py +155 -0
  307. venv/Lib/site-packages/keyring/backends/macOS/__init__.py +85 -0
  308. venv/Lib/site-packages/keyring/backends/macOS/api.py +184 -0
  309. venv/Lib/site-packages/keyring/backends/null.py +20 -0
  310. venv/Lib/site-packages/keyring/cli.py +220 -0
  311. venv/Lib/site-packages/keyring/compat/__init__.py +7 -0
  312. venv/Lib/site-packages/keyring/compat/properties.py +169 -0
  313. venv/Lib/site-packages/keyring/compat/py312.py +9 -0
  314. venv/Lib/site-packages/keyring/completion.py +55 -0
  315. venv/Lib/site-packages/keyring/core.py +202 -0
  316. venv/Lib/site-packages/keyring/credentials.py +85 -0
  317. venv/Lib/site-packages/keyring/devpi_client.py +29 -0
  318. venv/Lib/site-packages/keyring/errors.py +67 -0
  319. venv/Lib/site-packages/keyring/http.py +39 -0
  320. venv/Lib/site-packages/keyring/py.typed +0 -0
  321. venv/Lib/site-packages/keyring/testing/__init__.py +0 -0
  322. venv/Lib/site-packages/keyring/testing/backend.py +200 -0
  323. venv/Lib/site-packages/keyring/testing/util.py +68 -0
  324. venv/Lib/site-packages/keyring/util/__init__.py +11 -0
  325. venv/Lib/site-packages/keyring/util/platform_.py +40 -0
  326. venv/Lib/site-packages/markdown_it/__init__.py +6 -0
  327. venv/Lib/site-packages/markdown_it/_compat.py +1 -0
  328. venv/Lib/site-packages/markdown_it/_punycode.py +67 -0
  329. venv/Lib/site-packages/markdown_it/cli/__init__.py +0 -0
  330. venv/Lib/site-packages/markdown_it/cli/parse.py +127 -0
  331. venv/Lib/site-packages/markdown_it/common/__init__.py +0 -0
  332. venv/Lib/site-packages/markdown_it/common/entities.py +5 -0
  333. venv/Lib/site-packages/markdown_it/common/html_blocks.py +69 -0
  334. venv/Lib/site-packages/markdown_it/common/html_re.py +39 -0
  335. venv/Lib/site-packages/markdown_it/common/normalize_url.py +81 -0
  336. venv/Lib/site-packages/markdown_it/common/utils.py +313 -0
  337. venv/Lib/site-packages/markdown_it/helpers/__init__.py +6 -0
  338. venv/Lib/site-packages/markdown_it/helpers/parse_link_destination.py +83 -0
  339. venv/Lib/site-packages/markdown_it/helpers/parse_link_label.py +44 -0
  340. venv/Lib/site-packages/markdown_it/helpers/parse_link_title.py +75 -0
  341. venv/Lib/site-packages/markdown_it/main.py +351 -0
  342. venv/Lib/site-packages/markdown_it/parser_block.py +113 -0
  343. venv/Lib/site-packages/markdown_it/parser_core.py +46 -0
  344. venv/Lib/site-packages/markdown_it/parser_inline.py +215 -0
  345. venv/Lib/site-packages/markdown_it/presets/__init__.py +48 -0
  346. venv/Lib/site-packages/markdown_it/presets/commonmark.py +75 -0
  347. venv/Lib/site-packages/markdown_it/presets/default.py +36 -0
  348. venv/Lib/site-packages/markdown_it/presets/zero.py +44 -0
  349. venv/Lib/site-packages/markdown_it/py.typed +1 -0
  350. venv/Lib/site-packages/markdown_it/renderer.py +356 -0
  351. venv/Lib/site-packages/markdown_it/ruler.py +275 -0
  352. venv/Lib/site-packages/markdown_it/rules_block/__init__.py +28 -0
  353. venv/Lib/site-packages/markdown_it/rules_block/blockquote.py +368 -0
  354. venv/Lib/site-packages/markdown_it/rules_block/code.py +36 -0
  355. venv/Lib/site-packages/markdown_it/rules_block/fence.py +146 -0
  356. venv/Lib/site-packages/markdown_it/rules_block/heading.py +69 -0
  357. venv/Lib/site-packages/markdown_it/rules_block/hr.py +56 -0
  358. venv/Lib/site-packages/markdown_it/rules_block/html_block.py +90 -0
  359. venv/Lib/site-packages/markdown_it/rules_block/lheading.py +86 -0
  360. venv/Lib/site-packages/markdown_it/rules_block/list.py +408 -0
  361. venv/Lib/site-packages/markdown_it/rules_block/paragraph.py +66 -0
  362. venv/Lib/site-packages/markdown_it/rules_block/reference.py +235 -0
  363. venv/Lib/site-packages/markdown_it/rules_block/state_block.py +261 -0
  364. venv/Lib/site-packages/markdown_it/rules_block/table.py +250 -0
  365. venv/Lib/site-packages/markdown_it/rules_core/__init__.py +19 -0
  366. venv/Lib/site-packages/markdown_it/rules_core/block.py +13 -0
  367. venv/Lib/site-packages/markdown_it/rules_core/inline.py +10 -0
  368. venv/Lib/site-packages/markdown_it/rules_core/linkify.py +149 -0
  369. venv/Lib/site-packages/markdown_it/rules_core/normalize.py +19 -0
  370. venv/Lib/site-packages/markdown_it/rules_core/replacements.py +127 -0
  371. venv/Lib/site-packages/markdown_it/rules_core/smartquotes.py +202 -0
  372. venv/Lib/site-packages/markdown_it/rules_core/state_core.py +25 -0
  373. venv/Lib/site-packages/markdown_it/rules_core/text_join.py +53 -0
  374. venv/Lib/site-packages/markdown_it/rules_inline/__init__.py +31 -0
  375. venv/Lib/site-packages/markdown_it/rules_inline/autolink.py +77 -0
  376. venv/Lib/site-packages/markdown_it/rules_inline/backticks.py +72 -0
  377. venv/Lib/site-packages/markdown_it/rules_inline/balance_pairs.py +138 -0
  378. venv/Lib/site-packages/markdown_it/rules_inline/emphasis.py +102 -0
  379. venv/Lib/site-packages/markdown_it/rules_inline/entity.py +53 -0
  380. venv/Lib/site-packages/markdown_it/rules_inline/escape.py +93 -0
  381. venv/Lib/site-packages/markdown_it/rules_inline/fragments_join.py +54 -0
  382. venv/Lib/site-packages/markdown_it/rules_inline/html_inline.py +43 -0
  383. venv/Lib/site-packages/markdown_it/rules_inline/image.py +148 -0
  384. venv/Lib/site-packages/markdown_it/rules_inline/link.py +149 -0
  385. venv/Lib/site-packages/markdown_it/rules_inline/linkify.py +62 -0
  386. venv/Lib/site-packages/markdown_it/rules_inline/newline.py +44 -0
  387. venv/Lib/site-packages/markdown_it/rules_inline/state_inline.py +167 -0
  388. venv/Lib/site-packages/markdown_it/rules_inline/strikethrough.py +173 -0
  389. venv/Lib/site-packages/markdown_it/rules_inline/text.py +23 -0
  390. venv/Lib/site-packages/markdown_it/token.py +178 -0
  391. venv/Lib/site-packages/markdown_it/tree.py +333 -0
  392. venv/Lib/site-packages/markdown_it/utils.py +194 -0
  393. venv/Lib/site-packages/mdurl/__init__.py +18 -0
  394. venv/Lib/site-packages/mdurl/_decode.py +104 -0
  395. venv/Lib/site-packages/mdurl/_encode.py +85 -0
  396. venv/Lib/site-packages/mdurl/_format.py +27 -0
  397. venv/Lib/site-packages/mdurl/_parse.py +304 -0
  398. venv/Lib/site-packages/mdurl/_url.py +14 -0
  399. venv/Lib/site-packages/mdurl/py.typed +1 -0
  400. venv/Lib/site-packages/more_itertools/__init__.py +6 -0
  401. venv/Lib/site-packages/more_itertools/__init__.pyi +2 -0
  402. venv/Lib/site-packages/more_itertools/more.py +5457 -0
  403. venv/Lib/site-packages/more_itertools/more.pyi +963 -0
  404. venv/Lib/site-packages/more_itertools/py.typed +0 -0
  405. venv/Lib/site-packages/more_itertools/recipes.py +1599 -0
  406. venv/Lib/site-packages/more_itertools/recipes.pyi +234 -0
  407. venv/Lib/site-packages/nh3/__init__.py +5 -0
  408. venv/Lib/site-packages/nh3/__init__.pyi +42 -0
  409. venv/Lib/site-packages/nh3/py.typed +0 -0
  410. venv/Lib/site-packages/packaging/__init__.py +15 -0
  411. venv/Lib/site-packages/packaging/_elffile.py +108 -0
  412. venv/Lib/site-packages/packaging/_manylinux.py +262 -0
  413. venv/Lib/site-packages/packaging/_musllinux.py +85 -0
  414. venv/Lib/site-packages/packaging/_parser.py +393 -0
  415. venv/Lib/site-packages/packaging/_structures.py +33 -0
  416. venv/Lib/site-packages/packaging/_tokenizer.py +193 -0
  417. venv/Lib/site-packages/packaging/dependency_groups.py +302 -0
  418. venv/Lib/site-packages/packaging/direct_url.py +325 -0
  419. venv/Lib/site-packages/packaging/errors.py +94 -0
  420. venv/Lib/site-packages/packaging/licenses/__init__.py +186 -0
  421. venv/Lib/site-packages/packaging/licenses/_spdx.py +799 -0
  422. venv/Lib/site-packages/packaging/markers.py +492 -0
  423. venv/Lib/site-packages/packaging/metadata.py +964 -0
  424. venv/Lib/site-packages/packaging/py.typed +0 -0
  425. venv/Lib/site-packages/packaging/pylock.py +905 -0
  426. venv/Lib/site-packages/packaging/requirements.py +129 -0
  427. venv/Lib/site-packages/packaging/specifiers.py +1943 -0
  428. venv/Lib/site-packages/packaging/tags.py +932 -0
  429. venv/Lib/site-packages/packaging/utils.py +296 -0
  430. venv/Lib/site-packages/packaging/version.py +1231 -0
  431. venv/Lib/site-packages/pip/__init__.py +13 -0
  432. venv/Lib/site-packages/pip/__main__.py +24 -0
  433. venv/Lib/site-packages/pip/__pip-runner__.py +50 -0
  434. venv/Lib/site-packages/pip/_internal/__init__.py +18 -0
  435. venv/Lib/site-packages/pip/_internal/build_env.py +606 -0
  436. venv/Lib/site-packages/pip/_internal/cache.py +291 -0
  437. venv/Lib/site-packages/pip/_internal/cli/__init__.py +3 -0
  438. venv/Lib/site-packages/pip/_internal/cli/autocompletion.py +184 -0
  439. venv/Lib/site-packages/pip/_internal/cli/base_command.py +255 -0
  440. venv/Lib/site-packages/pip/_internal/cli/cmdoptions.py +1267 -0
  441. venv/Lib/site-packages/pip/_internal/cli/command_context.py +28 -0
  442. venv/Lib/site-packages/pip/_internal/cli/index_command.py +195 -0
  443. venv/Lib/site-packages/pip/_internal/cli/main.py +85 -0
  444. venv/Lib/site-packages/pip/_internal/cli/main_parser.py +136 -0
  445. venv/Lib/site-packages/pip/_internal/cli/parser.py +358 -0
  446. venv/Lib/site-packages/pip/_internal/cli/progress_bars.py +153 -0
  447. venv/Lib/site-packages/pip/_internal/cli/req_command.py +447 -0
  448. venv/Lib/site-packages/pip/_internal/cli/spinners.py +235 -0
  449. venv/Lib/site-packages/pip/_internal/cli/status_codes.py +6 -0
  450. venv/Lib/site-packages/pip/_internal/commands/__init__.py +139 -0
  451. venv/Lib/site-packages/pip/_internal/commands/cache.py +255 -0
  452. venv/Lib/site-packages/pip/_internal/commands/check.py +66 -0
  453. venv/Lib/site-packages/pip/_internal/commands/completion.py +136 -0
  454. venv/Lib/site-packages/pip/_internal/commands/configuration.py +288 -0
  455. venv/Lib/site-packages/pip/_internal/commands/debug.py +203 -0
  456. venv/Lib/site-packages/pip/_internal/commands/download.py +146 -0
  457. venv/Lib/site-packages/pip/_internal/commands/freeze.py +107 -0
  458. venv/Lib/site-packages/pip/_internal/commands/hash.py +58 -0
  459. venv/Lib/site-packages/pip/_internal/commands/help.py +40 -0
  460. venv/Lib/site-packages/pip/_internal/commands/index.py +166 -0
  461. venv/Lib/site-packages/pip/_internal/commands/inspect.py +92 -0
  462. venv/Lib/site-packages/pip/_internal/commands/install.py +810 -0
  463. venv/Lib/site-packages/pip/_internal/commands/list.py +398 -0
  464. venv/Lib/site-packages/pip/_internal/commands/lock.py +175 -0
  465. venv/Lib/site-packages/pip/_internal/commands/search.py +178 -0
  466. venv/Lib/site-packages/pip/_internal/commands/show.py +231 -0
  467. venv/Lib/site-packages/pip/_internal/commands/uninstall.py +113 -0
  468. venv/Lib/site-packages/pip/_internal/commands/wheel.py +171 -0
  469. venv/Lib/site-packages/pip/_internal/configuration.py +396 -0
  470. venv/Lib/site-packages/pip/_internal/distributions/__init__.py +21 -0
  471. venv/Lib/site-packages/pip/_internal/distributions/base.py +55 -0
  472. venv/Lib/site-packages/pip/_internal/distributions/installed.py +33 -0
  473. venv/Lib/site-packages/pip/_internal/distributions/sdist.py +164 -0
  474. venv/Lib/site-packages/pip/_internal/distributions/wheel.py +44 -0
  475. venv/Lib/site-packages/pip/_internal/exceptions.py +971 -0
  476. venv/Lib/site-packages/pip/_internal/index/__init__.py +1 -0
  477. venv/Lib/site-packages/pip/_internal/index/collector.py +488 -0
  478. venv/Lib/site-packages/pip/_internal/index/package_finder.py +1125 -0
  479. venv/Lib/site-packages/pip/_internal/index/sources.py +287 -0
  480. venv/Lib/site-packages/pip/_internal/locations/__init__.py +440 -0
  481. venv/Lib/site-packages/pip/_internal/locations/_distutils.py +173 -0
  482. venv/Lib/site-packages/pip/_internal/locations/_sysconfig.py +218 -0
  483. venv/Lib/site-packages/pip/_internal/locations/base.py +82 -0
  484. venv/Lib/site-packages/pip/_internal/main.py +12 -0
  485. venv/Lib/site-packages/pip/_internal/metadata/__init__.py +169 -0
  486. venv/Lib/site-packages/pip/_internal/metadata/_json.py +87 -0
  487. venv/Lib/site-packages/pip/_internal/metadata/base.py +685 -0
  488. venv/Lib/site-packages/pip/_internal/metadata/importlib/__init__.py +6 -0
  489. venv/Lib/site-packages/pip/_internal/metadata/importlib/_compat.py +87 -0
  490. venv/Lib/site-packages/pip/_internal/metadata/importlib/_dists.py +229 -0
  491. venv/Lib/site-packages/pip/_internal/metadata/importlib/_envs.py +143 -0
  492. venv/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +298 -0
  493. venv/Lib/site-packages/pip/_internal/models/__init__.py +1 -0
  494. venv/Lib/site-packages/pip/_internal/models/candidate.py +25 -0
  495. venv/Lib/site-packages/pip/_internal/models/direct_url.py +227 -0
  496. venv/Lib/site-packages/pip/_internal/models/format_control.py +78 -0
  497. venv/Lib/site-packages/pip/_internal/models/index.py +28 -0
  498. venv/Lib/site-packages/pip/_internal/models/installation_report.py +57 -0
  499. venv/Lib/site-packages/pip/_internal/models/link.py +617 -0
  500. venv/Lib/site-packages/pip/_internal/models/release_control.py +92 -0
  501. venv/Lib/site-packages/pip/_internal/models/scheme.py +25 -0
  502. venv/Lib/site-packages/pip/_internal/models/search_scope.py +126 -0
  503. venv/Lib/site-packages/pip/_internal/models/selection_prefs.py +56 -0
  504. venv/Lib/site-packages/pip/_internal/models/target_python.py +122 -0
  505. venv/Lib/site-packages/pip/_internal/models/wheel.py +80 -0
  506. venv/Lib/site-packages/pip/_internal/network/__init__.py +1 -0
  507. venv/Lib/site-packages/pip/_internal/network/auth.py +568 -0
  508. venv/Lib/site-packages/pip/_internal/network/cache.py +128 -0
  509. venv/Lib/site-packages/pip/_internal/network/download.py +341 -0
  510. venv/Lib/site-packages/pip/_internal/network/lazy_wheel.py +215 -0
  511. venv/Lib/site-packages/pip/_internal/network/session.py +532 -0
  512. venv/Lib/site-packages/pip/_internal/network/utils.py +98 -0
  513. venv/Lib/site-packages/pip/_internal/network/xmlrpc.py +61 -0
  514. venv/Lib/site-packages/pip/_internal/operations/__init__.py +0 -0
  515. venv/Lib/site-packages/pip/_internal/operations/build/__init__.py +0 -0
  516. venv/Lib/site-packages/pip/_internal/operations/build/build_tracker.py +140 -0
  517. venv/Lib/site-packages/pip/_internal/operations/build/metadata.py +38 -0
  518. venv/Lib/site-packages/pip/_internal/operations/build/metadata_editable.py +41 -0
  519. venv/Lib/site-packages/pip/_internal/operations/build/wheel.py +38 -0
  520. venv/Lib/site-packages/pip/_internal/operations/build/wheel_editable.py +47 -0
  521. venv/Lib/site-packages/pip/_internal/operations/check.py +175 -0
  522. venv/Lib/site-packages/pip/_internal/operations/freeze.py +259 -0
  523. venv/Lib/site-packages/pip/_internal/operations/install/__init__.py +1 -0
  524. venv/Lib/site-packages/pip/_internal/operations/install/wheel.py +745 -0
  525. venv/Lib/site-packages/pip/_internal/operations/prepare.py +747 -0
  526. venv/Lib/site-packages/pip/_internal/pyproject.py +123 -0
  527. venv/Lib/site-packages/pip/_internal/req/__init__.py +103 -0
  528. venv/Lib/site-packages/pip/_internal/req/constructors.py +568 -0
  529. venv/Lib/site-packages/pip/_internal/req/pep723.py +41 -0
  530. venv/Lib/site-packages/pip/_internal/req/req_dependency_group.py +75 -0
  531. venv/Lib/site-packages/pip/_internal/req/req_file.py +631 -0
  532. venv/Lib/site-packages/pip/_internal/req/req_install.py +828 -0
  533. venv/Lib/site-packages/pip/_internal/req/req_set.py +81 -0
  534. venv/Lib/site-packages/pip/_internal/req/req_uninstall.py +639 -0
  535. venv/Lib/site-packages/pip/_internal/resolution/__init__.py +0 -0
  536. venv/Lib/site-packages/pip/_internal/resolution/base.py +20 -0
  537. venv/Lib/site-packages/pip/_internal/resolution/legacy/__init__.py +0 -0
  538. venv/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +598 -0
  539. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/__init__.py +0 -0
  540. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +142 -0
  541. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +591 -0
  542. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +856 -0
  543. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +166 -0
  544. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +285 -0
  545. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py +98 -0
  546. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +251 -0
  547. venv/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py +332 -0
  548. venv/Lib/site-packages/pip/_internal/self_outdated_check.py +255 -0
  549. venv/Lib/site-packages/pip/_internal/utils/__init__.py +0 -0
  550. venv/Lib/site-packages/pip/_internal/utils/_jaraco_text.py +109 -0
  551. venv/Lib/site-packages/pip/_internal/utils/_log.py +38 -0
  552. venv/Lib/site-packages/pip/_internal/utils/appdirs.py +52 -0
  553. venv/Lib/site-packages/pip/_internal/utils/compat.py +85 -0
  554. venv/Lib/site-packages/pip/_internal/utils/compatibility_tags.py +201 -0
  555. venv/Lib/site-packages/pip/_internal/utils/datetime.py +28 -0
  556. venv/Lib/site-packages/pip/_internal/utils/deprecation.py +126 -0
  557. venv/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +87 -0
  558. venv/Lib/site-packages/pip/_internal/utils/egg_link.py +81 -0
  559. venv/Lib/site-packages/pip/_internal/utils/entrypoints.py +88 -0
  560. venv/Lib/site-packages/pip/_internal/utils/filesystem.py +203 -0
  561. venv/Lib/site-packages/pip/_internal/utils/filetypes.py +24 -0
  562. venv/Lib/site-packages/pip/_internal/utils/glibc.py +102 -0
  563. venv/Lib/site-packages/pip/_internal/utils/hashes.py +150 -0
  564. venv/Lib/site-packages/pip/_internal/utils/logging.py +396 -0
  565. venv/Lib/site-packages/pip/_internal/utils/misc.py +771 -0
  566. venv/Lib/site-packages/pip/_internal/utils/packaging.py +44 -0
  567. venv/Lib/site-packages/pip/_internal/utils/pylock.py +116 -0
  568. venv/Lib/site-packages/pip/_internal/utils/retry.py +45 -0
  569. venv/Lib/site-packages/pip/_internal/utils/subprocess.py +248 -0
  570. venv/Lib/site-packages/pip/_internal/utils/temp_dir.py +294 -0
  571. venv/Lib/site-packages/pip/_internal/utils/unpacking.py +362 -0
  572. venv/Lib/site-packages/pip/_internal/utils/urls.py +55 -0
  573. venv/Lib/site-packages/pip/_internal/utils/virtualenv.py +105 -0
  574. venv/Lib/site-packages/pip/_internal/utils/wheel.py +132 -0
  575. venv/Lib/site-packages/pip/_internal/vcs/__init__.py +15 -0
  576. venv/Lib/site-packages/pip/_internal/vcs/bazaar.py +130 -0
  577. venv/Lib/site-packages/pip/_internal/vcs/git.py +571 -0
  578. venv/Lib/site-packages/pip/_internal/vcs/mercurial.py +186 -0
  579. venv/Lib/site-packages/pip/_internal/vcs/subversion.py +335 -0
  580. venv/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +695 -0
  581. venv/Lib/site-packages/pip/_internal/wheel_builder.py +261 -0
  582. venv/Lib/site-packages/pip/_vendor/__init__.py +117 -0
  583. venv/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py +32 -0
  584. venv/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py +70 -0
  585. venv/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +167 -0
  586. venv/Lib/site-packages/pip/_vendor/cachecontrol/cache.py +75 -0
  587. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py +8 -0
  588. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py +145 -0
  589. venv/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py +48 -0
  590. venv/Lib/site-packages/pip/_vendor/cachecontrol/controller.py +511 -0
  591. venv/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py +121 -0
  592. venv/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +157 -0
  593. venv/Lib/site-packages/pip/_vendor/cachecontrol/py.typed +0 -0
  594. venv/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +146 -0
  595. venv/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py +43 -0
  596. venv/Lib/site-packages/pip/_vendor/certifi/__init__.py +4 -0
  597. venv/Lib/site-packages/pip/_vendor/certifi/__main__.py +12 -0
  598. venv/Lib/site-packages/pip/_vendor/certifi/core.py +83 -0
  599. venv/Lib/site-packages/pip/_vendor/certifi/py.typed +0 -0
  600. venv/Lib/site-packages/pip/_vendor/dependency_groups/__init__.py +13 -0
  601. venv/Lib/site-packages/pip/_vendor/dependency_groups/__main__.py +65 -0
  602. venv/Lib/site-packages/pip/_vendor/dependency_groups/_implementation.py +209 -0
  603. venv/Lib/site-packages/pip/_vendor/dependency_groups/_lint_dependency_groups.py +59 -0
  604. venv/Lib/site-packages/pip/_vendor/dependency_groups/_pip_wrapper.py +62 -0
  605. venv/Lib/site-packages/pip/_vendor/dependency_groups/_toml_compat.py +9 -0
  606. venv/Lib/site-packages/pip/_vendor/dependency_groups/py.typed +0 -0
  607. venv/Lib/site-packages/pip/_vendor/distlib/__init__.py +33 -0
  608. venv/Lib/site-packages/pip/_vendor/distlib/compat.py +1137 -0
  609. venv/Lib/site-packages/pip/_vendor/distlib/resources.py +358 -0
  610. venv/Lib/site-packages/pip/_vendor/distlib/scripts.py +447 -0
  611. venv/Lib/site-packages/pip/_vendor/distlib/util.py +1984 -0
  612. venv/Lib/site-packages/pip/_vendor/distro/__init__.py +54 -0
  613. venv/Lib/site-packages/pip/_vendor/distro/__main__.py +4 -0
  614. venv/Lib/site-packages/pip/_vendor/distro/distro.py +1403 -0
  615. venv/Lib/site-packages/pip/_vendor/distro/py.typed +0 -0
  616. venv/Lib/site-packages/pip/_vendor/idna/__init__.py +45 -0
  617. venv/Lib/site-packages/pip/_vendor/idna/codec.py +122 -0
  618. venv/Lib/site-packages/pip/_vendor/idna/compat.py +15 -0
  619. venv/Lib/site-packages/pip/_vendor/idna/core.py +437 -0
  620. venv/Lib/site-packages/pip/_vendor/idna/idnadata.py +4309 -0
  621. venv/Lib/site-packages/pip/_vendor/idna/intranges.py +57 -0
  622. venv/Lib/site-packages/pip/_vendor/idna/package_data.py +1 -0
  623. venv/Lib/site-packages/pip/_vendor/idna/py.typed +0 -0
  624. venv/Lib/site-packages/pip/_vendor/idna/uts46data.py +8841 -0
  625. venv/Lib/site-packages/pip/_vendor/msgpack/__init__.py +55 -0
  626. venv/Lib/site-packages/pip/_vendor/msgpack/exceptions.py +48 -0
  627. venv/Lib/site-packages/pip/_vendor/msgpack/ext.py +170 -0
  628. venv/Lib/site-packages/pip/_vendor/msgpack/fallback.py +929 -0
  629. venv/Lib/site-packages/pip/_vendor/packaging/__init__.py +15 -0
  630. venv/Lib/site-packages/pip/_vendor/packaging/_elffile.py +108 -0
  631. venv/Lib/site-packages/pip/_vendor/packaging/_manylinux.py +262 -0
  632. venv/Lib/site-packages/pip/_vendor/packaging/_musllinux.py +85 -0
  633. venv/Lib/site-packages/pip/_vendor/packaging/_parser.py +365 -0
  634. venv/Lib/site-packages/pip/_vendor/packaging/_structures.py +69 -0
  635. venv/Lib/site-packages/pip/_vendor/packaging/_tokenizer.py +193 -0
  636. venv/Lib/site-packages/pip/_vendor/packaging/licenses/__init__.py +147 -0
  637. venv/Lib/site-packages/pip/_vendor/packaging/licenses/_spdx.py +799 -0
  638. venv/Lib/site-packages/pip/_vendor/packaging/markers.py +388 -0
  639. venv/Lib/site-packages/pip/_vendor/packaging/metadata.py +978 -0
  640. venv/Lib/site-packages/pip/_vendor/packaging/py.typed +0 -0
  641. venv/Lib/site-packages/pip/_vendor/packaging/pylock.py +635 -0
  642. venv/Lib/site-packages/pip/_vendor/packaging/requirements.py +86 -0
  643. venv/Lib/site-packages/pip/_vendor/packaging/specifiers.py +1068 -0
  644. venv/Lib/site-packages/pip/_vendor/packaging/tags.py +651 -0
  645. venv/Lib/site-packages/pip/_vendor/packaging/utils.py +158 -0
  646. venv/Lib/site-packages/pip/_vendor/packaging/version.py +792 -0
  647. venv/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py +3676 -0
  648. venv/Lib/site-packages/pip/_vendor/platformdirs/__init__.py +631 -0
  649. venv/Lib/site-packages/pip/_vendor/platformdirs/__main__.py +55 -0
  650. venv/Lib/site-packages/pip/_vendor/platformdirs/android.py +249 -0
  651. venv/Lib/site-packages/pip/_vendor/platformdirs/api.py +299 -0
  652. venv/Lib/site-packages/pip/_vendor/platformdirs/macos.py +146 -0
  653. venv/Lib/site-packages/pip/_vendor/platformdirs/py.typed +0 -0
  654. venv/Lib/site-packages/pip/_vendor/platformdirs/unix.py +272 -0
  655. venv/Lib/site-packages/pip/_vendor/platformdirs/version.py +34 -0
  656. venv/Lib/site-packages/pip/_vendor/platformdirs/windows.py +278 -0
  657. venv/Lib/site-packages/pip/_vendor/pygments/__init__.py +82 -0
  658. venv/Lib/site-packages/pip/_vendor/pygments/__main__.py +17 -0
  659. venv/Lib/site-packages/pip/_vendor/pygments/console.py +70 -0
  660. venv/Lib/site-packages/pip/_vendor/pygments/filter.py +70 -0
  661. venv/Lib/site-packages/pip/_vendor/pygments/filters/__init__.py +940 -0
  662. venv/Lib/site-packages/pip/_vendor/pygments/formatter.py +129 -0
  663. venv/Lib/site-packages/pip/_vendor/pygments/formatters/__init__.py +157 -0
  664. venv/Lib/site-packages/pip/_vendor/pygments/formatters/_mapping.py +23 -0
  665. venv/Lib/site-packages/pip/_vendor/pygments/lexer.py +963 -0
  666. venv/Lib/site-packages/pip/_vendor/pygments/lexers/__init__.py +362 -0
  667. venv/Lib/site-packages/pip/_vendor/pygments/lexers/_mapping.py +602 -0
  668. venv/Lib/site-packages/pip/_vendor/pygments/lexers/python.py +1201 -0
  669. venv/Lib/site-packages/pip/_vendor/pygments/modeline.py +43 -0
  670. venv/Lib/site-packages/pip/_vendor/pygments/plugin.py +72 -0
  671. venv/Lib/site-packages/pip/_vendor/pygments/regexopt.py +91 -0
  672. venv/Lib/site-packages/pip/_vendor/pygments/scanner.py +104 -0
  673. venv/Lib/site-packages/pip/_vendor/pygments/sphinxext.py +247 -0
  674. venv/Lib/site-packages/pip/_vendor/pygments/style.py +203 -0
  675. venv/Lib/site-packages/pip/_vendor/pygments/styles/__init__.py +61 -0
  676. venv/Lib/site-packages/pip/_vendor/pygments/styles/_mapping.py +54 -0
  677. venv/Lib/site-packages/pip/_vendor/pygments/token.py +214 -0
  678. venv/Lib/site-packages/pip/_vendor/pygments/unistring.py +153 -0
  679. venv/Lib/site-packages/pip/_vendor/pygments/util.py +324 -0
  680. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/__init__.py +31 -0
  681. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_impl.py +410 -0
  682. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/__init__.py +21 -0
  683. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py +389 -0
  684. venv/Lib/site-packages/pip/_vendor/pyproject_hooks/py.typed +0 -0
  685. venv/Lib/site-packages/pip/_vendor/requests/__init__.py +179 -0
  686. venv/Lib/site-packages/pip/_vendor/requests/__version__.py +14 -0
  687. venv/Lib/site-packages/pip/_vendor/requests/_internal_utils.py +50 -0
  688. venv/Lib/site-packages/pip/_vendor/requests/adapters.py +696 -0
  689. venv/Lib/site-packages/pip/_vendor/requests/api.py +157 -0
  690. venv/Lib/site-packages/pip/_vendor/requests/auth.py +314 -0
  691. venv/Lib/site-packages/pip/_vendor/requests/certs.py +17 -0
  692. venv/Lib/site-packages/pip/_vendor/requests/compat.py +90 -0
  693. venv/Lib/site-packages/pip/_vendor/requests/cookies.py +561 -0
  694. venv/Lib/site-packages/pip/_vendor/requests/exceptions.py +151 -0
  695. venv/Lib/site-packages/pip/_vendor/requests/help.py +127 -0
  696. venv/Lib/site-packages/pip/_vendor/requests/hooks.py +33 -0
  697. venv/Lib/site-packages/pip/_vendor/requests/models.py +1039 -0
  698. venv/Lib/site-packages/pip/_vendor/requests/packages.py +25 -0
  699. venv/Lib/site-packages/pip/_vendor/requests/sessions.py +831 -0
  700. venv/Lib/site-packages/pip/_vendor/requests/status_codes.py +128 -0
  701. venv/Lib/site-packages/pip/_vendor/requests/structures.py +99 -0
  702. venv/Lib/site-packages/pip/_vendor/requests/utils.py +1086 -0
  703. venv/Lib/site-packages/pip/_vendor/resolvelib/__init__.py +27 -0
  704. venv/Lib/site-packages/pip/_vendor/resolvelib/providers.py +196 -0
  705. venv/Lib/site-packages/pip/_vendor/resolvelib/py.typed +0 -0
  706. venv/Lib/site-packages/pip/_vendor/resolvelib/reporters.py +55 -0
  707. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/__init__.py +27 -0
  708. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/abstract.py +47 -0
  709. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/criterion.py +48 -0
  710. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/exceptions.py +57 -0
  711. venv/Lib/site-packages/pip/_vendor/resolvelib/resolvers/resolution.py +627 -0
  712. venv/Lib/site-packages/pip/_vendor/resolvelib/structs.py +209 -0
  713. venv/Lib/site-packages/pip/_vendor/rich/__init__.py +177 -0
  714. venv/Lib/site-packages/pip/_vendor/rich/__main__.py +245 -0
  715. venv/Lib/site-packages/pip/_vendor/rich/_cell_widths.py +454 -0
  716. venv/Lib/site-packages/pip/_vendor/rich/_emoji_codes.py +3610 -0
  717. venv/Lib/site-packages/pip/_vendor/rich/_emoji_replace.py +32 -0
  718. venv/Lib/site-packages/pip/_vendor/rich/_export_format.py +76 -0
  719. venv/Lib/site-packages/pip/_vendor/rich/_extension.py +10 -0
  720. venv/Lib/site-packages/pip/_vendor/rich/_fileno.py +24 -0
  721. venv/Lib/site-packages/pip/_vendor/rich/_inspect.py +268 -0
  722. venv/Lib/site-packages/pip/_vendor/rich/_log_render.py +94 -0
  723. venv/Lib/site-packages/pip/_vendor/rich/_loop.py +43 -0
  724. venv/Lib/site-packages/pip/_vendor/rich/_null_file.py +69 -0
  725. venv/Lib/site-packages/pip/_vendor/rich/_palettes.py +309 -0
  726. venv/Lib/site-packages/pip/_vendor/rich/_pick.py +17 -0
  727. venv/Lib/site-packages/pip/_vendor/rich/_ratio.py +153 -0
  728. venv/Lib/site-packages/pip/_vendor/rich/_spinners.py +482 -0
  729. venv/Lib/site-packages/pip/_vendor/rich/_stack.py +16 -0
  730. venv/Lib/site-packages/pip/_vendor/rich/_timer.py +19 -0
  731. venv/Lib/site-packages/pip/_vendor/rich/_win32_console.py +661 -0
  732. venv/Lib/site-packages/pip/_vendor/rich/_windows.py +71 -0
  733. venv/Lib/site-packages/pip/_vendor/rich/_windows_renderer.py +56 -0
  734. venv/Lib/site-packages/pip/_vendor/rich/_wrap.py +93 -0
  735. venv/Lib/site-packages/pip/_vendor/rich/abc.py +33 -0
  736. venv/Lib/site-packages/pip/_vendor/rich/align.py +306 -0
  737. venv/Lib/site-packages/pip/_vendor/rich/ansi.py +241 -0
  738. venv/Lib/site-packages/pip/_vendor/rich/bar.py +93 -0
  739. venv/Lib/site-packages/pip/_vendor/rich/box.py +474 -0
  740. venv/Lib/site-packages/pip/_vendor/rich/cells.py +174 -0
  741. venv/Lib/site-packages/pip/_vendor/rich/color.py +621 -0
  742. venv/Lib/site-packages/pip/_vendor/rich/color_triplet.py +38 -0
  743. venv/Lib/site-packages/pip/_vendor/rich/columns.py +187 -0
  744. venv/Lib/site-packages/pip/_vendor/rich/console.py +2680 -0
  745. venv/Lib/site-packages/pip/_vendor/rich/constrain.py +37 -0
  746. venv/Lib/site-packages/pip/_vendor/rich/containers.py +167 -0
  747. venv/Lib/site-packages/pip/_vendor/rich/control.py +219 -0
  748. venv/Lib/site-packages/pip/_vendor/rich/default_styles.py +193 -0
  749. venv/Lib/site-packages/pip/_vendor/rich/diagnose.py +39 -0
  750. venv/Lib/site-packages/pip/_vendor/rich/emoji.py +91 -0
  751. venv/Lib/site-packages/pip/_vendor/rich/errors.py +34 -0
  752. venv/Lib/site-packages/pip/_vendor/rich/file_proxy.py +57 -0
  753. venv/Lib/site-packages/pip/_vendor/rich/filesize.py +88 -0
  754. venv/Lib/site-packages/pip/_vendor/rich/highlighter.py +232 -0
  755. venv/Lib/site-packages/pip/_vendor/rich/json.py +139 -0
  756. venv/Lib/site-packages/pip/_vendor/rich/jupyter.py +101 -0
  757. venv/Lib/site-packages/pip/_vendor/rich/layout.py +442 -0
  758. venv/Lib/site-packages/pip/_vendor/rich/live.py +400 -0
  759. venv/Lib/site-packages/pip/_vendor/rich/live_render.py +106 -0
  760. venv/Lib/site-packages/pip/_vendor/rich/logging.py +297 -0
  761. venv/Lib/site-packages/pip/_vendor/rich/markup.py +251 -0
  762. venv/Lib/site-packages/pip/_vendor/rich/measure.py +151 -0
  763. venv/Lib/site-packages/pip/_vendor/rich/padding.py +141 -0
  764. venv/Lib/site-packages/pip/_vendor/rich/pager.py +34 -0
  765. venv/Lib/site-packages/pip/_vendor/rich/palette.py +100 -0
  766. venv/Lib/site-packages/pip/_vendor/rich/panel.py +317 -0
  767. venv/Lib/site-packages/pip/_vendor/rich/pretty.py +1016 -0
  768. venv/Lib/site-packages/pip/_vendor/rich/progress.py +1715 -0
  769. venv/Lib/site-packages/pip/_vendor/rich/progress_bar.py +223 -0
  770. venv/Lib/site-packages/pip/_vendor/rich/prompt.py +400 -0
  771. venv/Lib/site-packages/pip/_vendor/rich/protocol.py +42 -0
  772. venv/Lib/site-packages/pip/_vendor/rich/py.typed +0 -0
  773. venv/Lib/site-packages/pip/_vendor/rich/region.py +10 -0
  774. venv/Lib/site-packages/pip/_vendor/rich/repr.py +149 -0
  775. venv/Lib/site-packages/pip/_vendor/rich/rule.py +130 -0
  776. venv/Lib/site-packages/pip/_vendor/rich/scope.py +86 -0
  777. venv/Lib/site-packages/pip/_vendor/rich/screen.py +54 -0
  778. venv/Lib/site-packages/pip/_vendor/rich/segment.py +752 -0
  779. venv/Lib/site-packages/pip/_vendor/rich/spinner.py +132 -0
  780. venv/Lib/site-packages/pip/_vendor/rich/status.py +131 -0
  781. venv/Lib/site-packages/pip/_vendor/rich/style.py +792 -0
  782. venv/Lib/site-packages/pip/_vendor/rich/styled.py +42 -0
  783. venv/Lib/site-packages/pip/_vendor/rich/syntax.py +985 -0
  784. venv/Lib/site-packages/pip/_vendor/rich/table.py +1006 -0
  785. venv/Lib/site-packages/pip/_vendor/rich/terminal_theme.py +153 -0
  786. venv/Lib/site-packages/pip/_vendor/rich/text.py +1361 -0
  787. venv/Lib/site-packages/pip/_vendor/rich/theme.py +115 -0
  788. venv/Lib/site-packages/pip/_vendor/rich/themes.py +5 -0
  789. venv/Lib/site-packages/pip/_vendor/rich/traceback.py +899 -0
  790. venv/Lib/site-packages/pip/_vendor/rich/tree.py +257 -0
  791. venv/Lib/site-packages/pip/_vendor/tomli/__init__.py +8 -0
  792. venv/Lib/site-packages/pip/_vendor/tomli/_parser.py +777 -0
  793. venv/Lib/site-packages/pip/_vendor/tomli/_re.py +115 -0
  794. venv/Lib/site-packages/pip/_vendor/tomli/_types.py +10 -0
  795. venv/Lib/site-packages/pip/_vendor/tomli/py.typed +1 -0
  796. venv/Lib/site-packages/pip/_vendor/tomli_w/__init__.py +4 -0
  797. venv/Lib/site-packages/pip/_vendor/tomli_w/_writer.py +229 -0
  798. venv/Lib/site-packages/pip/_vendor/tomli_w/py.typed +1 -0
  799. venv/Lib/site-packages/pip/_vendor/truststore/__init__.py +36 -0
  800. venv/Lib/site-packages/pip/_vendor/truststore/_api.py +341 -0
  801. venv/Lib/site-packages/pip/_vendor/truststore/_macos.py +571 -0
  802. venv/Lib/site-packages/pip/_vendor/truststore/_openssl.py +68 -0
  803. venv/Lib/site-packages/pip/_vendor/truststore/_ssl_constants.py +31 -0
  804. venv/Lib/site-packages/pip/_vendor/truststore/_windows.py +567 -0
  805. venv/Lib/site-packages/pip/_vendor/truststore/py.typed +0 -0
  806. venv/Lib/site-packages/pip/_vendor/urllib3/__init__.py +102 -0
  807. venv/Lib/site-packages/pip/_vendor/urllib3/_collections.py +355 -0
  808. venv/Lib/site-packages/pip/_vendor/urllib3/_version.py +2 -0
  809. venv/Lib/site-packages/pip/_vendor/urllib3/connection.py +572 -0
  810. venv/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +1140 -0
  811. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/__init__.py +0 -0
  812. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py +36 -0
  813. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py +0 -0
  814. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py +519 -0
  815. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py +397 -0
  816. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py +314 -0
  817. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py +130 -0
  818. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py +518 -0
  819. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +920 -0
  820. venv/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py +216 -0
  821. venv/Lib/site-packages/pip/_vendor/urllib3/exceptions.py +323 -0
  822. venv/Lib/site-packages/pip/_vendor/urllib3/fields.py +274 -0
  823. venv/Lib/site-packages/pip/_vendor/urllib3/filepost.py +98 -0
  824. venv/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py +0 -0
  825. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py +0 -0
  826. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py +51 -0
  827. venv/Lib/site-packages/pip/_vendor/urllib3/packages/backports/weakref_finalize.py +155 -0
  828. venv/Lib/site-packages/pip/_vendor/urllib3/packages/six.py +1076 -0
  829. venv/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +540 -0
  830. venv/Lib/site-packages/pip/_vendor/urllib3/request.py +191 -0
  831. venv/Lib/site-packages/pip/_vendor/urllib3/response.py +879 -0
  832. venv/Lib/site-packages/pip/_vendor/urllib3/util/__init__.py +49 -0
  833. venv/Lib/site-packages/pip/_vendor/urllib3/util/connection.py +149 -0
  834. venv/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py +57 -0
  835. venv/Lib/site-packages/pip/_vendor/urllib3/util/queue.py +22 -0
  836. venv/Lib/site-packages/pip/_vendor/urllib3/util/request.py +137 -0
  837. venv/Lib/site-packages/pip/_vendor/urllib3/util/response.py +107 -0
  838. venv/Lib/site-packages/pip/_vendor/urllib3/util/retry.py +622 -0
  839. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py +504 -0
  840. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssl_match_hostname.py +159 -0
  841. venv/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py +221 -0
  842. venv/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py +271 -0
  843. venv/Lib/site-packages/pip/_vendor/urllib3/util/url.py +435 -0
  844. venv/Lib/site-packages/pip/_vendor/urllib3/util/wait.py +152 -0
  845. venv/Lib/site-packages/pip/py.typed +4 -0
  846. venv/Lib/site-packages/pluggy/__init__.py +30 -0
  847. venv/Lib/site-packages/pluggy/_callers.py +169 -0
  848. venv/Lib/site-packages/pluggy/_hooks.py +714 -0
  849. venv/Lib/site-packages/pluggy/_manager.py +523 -0
  850. venv/Lib/site-packages/pluggy/_result.py +107 -0
  851. venv/Lib/site-packages/pluggy/_tracing.py +72 -0
  852. venv/Lib/site-packages/pluggy/_version.py +21 -0
  853. venv/Lib/site-packages/pluggy/_warnings.py +27 -0
  854. venv/Lib/site-packages/pluggy/py.typed +0 -0
  855. venv/Lib/site-packages/py.py +15 -0
  856. venv/Lib/site-packages/pydantic/__init__.py +456 -0
  857. venv/Lib/site-packages/pydantic/_internal/__init__.py +0 -0
  858. venv/Lib/site-packages/pydantic/_internal/_config.py +386 -0
  859. venv/Lib/site-packages/pydantic/_internal/_core_metadata.py +97 -0
  860. venv/Lib/site-packages/pydantic/_internal/_core_utils.py +174 -0
  861. venv/Lib/site-packages/pydantic/_internal/_dataclasses.py +315 -0
  862. venv/Lib/site-packages/pydantic/_internal/_decorators.py +873 -0
  863. venv/Lib/site-packages/pydantic/_internal/_decorators_v1.py +174 -0
  864. venv/Lib/site-packages/pydantic/_internal/_discriminated_union.py +494 -0
  865. venv/Lib/site-packages/pydantic/_internal/_docs_extraction.py +113 -0
  866. venv/Lib/site-packages/pydantic/_internal/_fields.py +729 -0
  867. venv/Lib/site-packages/pydantic/_internal/_forward_ref.py +23 -0
  868. venv/Lib/site-packages/pydantic/_internal/_generate_schema.py +2934 -0
  869. venv/Lib/site-packages/pydantic/_internal/_generics.py +530 -0
  870. venv/Lib/site-packages/pydantic/_internal/_git.py +27 -0
  871. venv/Lib/site-packages/pydantic/_internal/_import_utils.py +20 -0
  872. venv/Lib/site-packages/pydantic/_internal/_internal_dataclass.py +7 -0
  873. venv/Lib/site-packages/pydantic/_internal/_known_annotated_metadata.py +403 -0
  874. venv/Lib/site-packages/pydantic/_internal/_mock_val_ser.py +228 -0
  875. venv/Lib/site-packages/pydantic/_internal/_model_construction.py +868 -0
  876. venv/Lib/site-packages/pydantic/_internal/_namespace_utils.py +293 -0
  877. venv/Lib/site-packages/pydantic/_internal/_repr.py +124 -0
  878. venv/Lib/site-packages/pydantic/_internal/_schema_gather.py +212 -0
  879. venv/Lib/site-packages/pydantic/_internal/_schema_generation_shared.py +125 -0
  880. venv/Lib/site-packages/pydantic/_internal/_serializers.py +53 -0
  881. venv/Lib/site-packages/pydantic/_internal/_signature.py +189 -0
  882. venv/Lib/site-packages/pydantic/_internal/_typing_extra.py +785 -0
  883. venv/Lib/site-packages/pydantic/_internal/_utils.py +446 -0
  884. venv/Lib/site-packages/pydantic/_internal/_validate_call.py +141 -0
  885. venv/Lib/site-packages/pydantic/_internal/_validators.py +534 -0
  886. venv/Lib/site-packages/pydantic/_migration.py +316 -0
  887. venv/Lib/site-packages/pydantic/alias_generators.py +62 -0
  888. venv/Lib/site-packages/pydantic/aliases.py +135 -0
  889. venv/Lib/site-packages/pydantic/annotated_handlers.py +122 -0
  890. venv/Lib/site-packages/pydantic/class_validators.py +5 -0
  891. venv/Lib/site-packages/pydantic/color.py +604 -0
  892. venv/Lib/site-packages/pydantic/config.py +1296 -0
  893. venv/Lib/site-packages/pydantic/dataclasses.py +413 -0
  894. venv/Lib/site-packages/pydantic/datetime_parse.py +5 -0
  895. venv/Lib/site-packages/pydantic/decorator.py +5 -0
  896. venv/Lib/site-packages/pydantic/deprecated/__init__.py +0 -0
  897. venv/Lib/site-packages/pydantic/deprecated/class_validators.py +256 -0
  898. venv/Lib/site-packages/pydantic/deprecated/config.py +72 -0
  899. venv/Lib/site-packages/pydantic/deprecated/copy_internals.py +224 -0
  900. venv/Lib/site-packages/pydantic/deprecated/decorator.py +284 -0
  901. venv/Lib/site-packages/pydantic/deprecated/json.py +141 -0
  902. venv/Lib/site-packages/pydantic/deprecated/parse.py +80 -0
  903. venv/Lib/site-packages/pydantic/deprecated/tools.py +103 -0
  904. venv/Lib/site-packages/pydantic/env_settings.py +5 -0
  905. venv/Lib/site-packages/pydantic/error_wrappers.py +5 -0
  906. venv/Lib/site-packages/pydantic/errors.py +189 -0
  907. venv/Lib/site-packages/pydantic/experimental/__init__.py +1 -0
  908. venv/Lib/site-packages/pydantic/experimental/arguments_schema.py +44 -0
  909. venv/Lib/site-packages/pydantic/experimental/missing_sentinel.py +5 -0
  910. venv/Lib/site-packages/pydantic/experimental/pipeline.py +663 -0
  911. venv/Lib/site-packages/pydantic/fields.py +1892 -0
  912. venv/Lib/site-packages/pydantic/functional_serializers.py +470 -0
  913. venv/Lib/site-packages/pydantic/functional_validators.py +889 -0
  914. venv/Lib/site-packages/pydantic/generics.py +5 -0
  915. venv/Lib/site-packages/pydantic/json.py +5 -0
  916. venv/Lib/site-packages/pydantic/json_schema.py +2911 -0
  917. venv/Lib/site-packages/pydantic/main.py +1838 -0
  918. venv/Lib/site-packages/pydantic/mypy.py +1412 -0
  919. venv/Lib/site-packages/pydantic/networks.py +1332 -0
  920. venv/Lib/site-packages/pydantic/parse.py +5 -0
  921. venv/Lib/site-packages/pydantic/plugin/__init__.py +193 -0
  922. venv/Lib/site-packages/pydantic/plugin/_loader.py +58 -0
  923. venv/Lib/site-packages/pydantic/plugin/_schema_validator.py +143 -0
  924. venv/Lib/site-packages/pydantic/py.typed +0 -0
  925. venv/Lib/site-packages/pydantic/root_model.py +157 -0
  926. venv/Lib/site-packages/pydantic/schema.py +5 -0
  927. venv/Lib/site-packages/pydantic/tools.py +5 -0
  928. venv/Lib/site-packages/pydantic/type_adapter.py +801 -0
  929. venv/Lib/site-packages/pydantic/types.py +3310 -0
  930. venv/Lib/site-packages/pydantic/typing.py +5 -0
  931. venv/Lib/site-packages/pydantic/utils.py +5 -0
  932. venv/Lib/site-packages/pydantic/v1/__init__.py +131 -0
  933. venv/Lib/site-packages/pydantic/v1/_hypothesis_plugin.py +391 -0
  934. venv/Lib/site-packages/pydantic/v1/annotated_types.py +72 -0
  935. venv/Lib/site-packages/pydantic/v1/class_validators.py +361 -0
  936. venv/Lib/site-packages/pydantic/v1/color.py +494 -0
  937. venv/Lib/site-packages/pydantic/v1/config.py +191 -0
  938. venv/Lib/site-packages/pydantic/v1/dataclasses.py +500 -0
  939. venv/Lib/site-packages/pydantic/v1/datetime_parse.py +248 -0
  940. venv/Lib/site-packages/pydantic/v1/decorator.py +264 -0
  941. venv/Lib/site-packages/pydantic/v1/env_settings.py +350 -0
  942. venv/Lib/site-packages/pydantic/v1/error_wrappers.py +161 -0
  943. venv/Lib/site-packages/pydantic/v1/errors.py +646 -0
  944. venv/Lib/site-packages/pydantic/v1/fields.py +1253 -0
  945. venv/Lib/site-packages/pydantic/v1/generics.py +400 -0
  946. venv/Lib/site-packages/pydantic/v1/json.py +112 -0
  947. venv/Lib/site-packages/pydantic/v1/main.py +1130 -0
  948. venv/Lib/site-packages/pydantic/v1/mypy.py +949 -0
  949. venv/Lib/site-packages/pydantic/v1/networks.py +747 -0
  950. venv/Lib/site-packages/pydantic/v1/parse.py +66 -0
  951. venv/Lib/site-packages/pydantic/v1/py.typed +0 -0
  952. venv/Lib/site-packages/pydantic/v1/schema.py +1163 -0
  953. venv/Lib/site-packages/pydantic/v1/tools.py +92 -0
  954. venv/Lib/site-packages/pydantic/v1/types.py +1205 -0
  955. venv/Lib/site-packages/pydantic/v1/typing.py +627 -0
  956. venv/Lib/site-packages/pydantic/v1/utils.py +807 -0
  957. venv/Lib/site-packages/pydantic/v1/validators.py +768 -0
  958. venv/Lib/site-packages/pydantic/v1/version.py +38 -0
  959. venv/Lib/site-packages/pydantic/validate_call_decorator.py +116 -0
  960. venv/Lib/site-packages/pydantic/validators.py +5 -0
  961. venv/Lib/site-packages/pydantic/version.py +113 -0
  962. venv/Lib/site-packages/pydantic/warnings.py +122 -0
  963. venv/Lib/site-packages/pydantic_core/__init__.py +171 -0
  964. venv/Lib/site-packages/pydantic_core/_pydantic_core.pyi +1056 -0
  965. venv/Lib/site-packages/pydantic_core/core_schema.py +4461 -0
  966. venv/Lib/site-packages/pydantic_core/py.typed +0 -0
  967. venv/Lib/site-packages/pygments/__init__.py +82 -0
  968. venv/Lib/site-packages/pygments/__main__.py +17 -0
  969. venv/Lib/site-packages/pygments/cmdline.py +668 -0
  970. venv/Lib/site-packages/pygments/console.py +70 -0
  971. venv/Lib/site-packages/pygments/filter.py +70 -0
  972. venv/Lib/site-packages/pygments/filters/__init__.py +942 -0
  973. venv/Lib/site-packages/pygments/formatter.py +129 -0
  974. venv/Lib/site-packages/pygments/formatters/__init__.py +157 -0
  975. venv/Lib/site-packages/pygments/formatters/_mapping.py +23 -0
  976. venv/Lib/site-packages/pygments/formatters/bbcode.py +108 -0
  977. venv/Lib/site-packages/pygments/formatters/groff.py +170 -0
  978. venv/Lib/site-packages/pygments/formatters/html.py +997 -0
  979. venv/Lib/site-packages/pygments/formatters/img.py +686 -0
  980. venv/Lib/site-packages/pygments/formatters/irc.py +153 -0
  981. venv/Lib/site-packages/pygments/formatters/latex.py +518 -0
  982. venv/Lib/site-packages/pygments/formatters/other.py +160 -0
  983. venv/Lib/site-packages/pygments/formatters/pangomarkup.py +83 -0
  984. venv/Lib/site-packages/pygments/formatters/rtf.py +349 -0
  985. venv/Lib/site-packages/pygments/formatters/svg.py +185 -0
  986. venv/Lib/site-packages/pygments/formatters/terminal.py +127 -0
  987. venv/Lib/site-packages/pygments/formatters/terminal256.py +338 -0
  988. venv/Lib/site-packages/pygments/lexer.py +963 -0
  989. venv/Lib/site-packages/pygments/lexers/__init__.py +362 -0
  990. venv/Lib/site-packages/pygments/lexers/_ada_builtins.py +103 -0
  991. venv/Lib/site-packages/pygments/lexers/_asy_builtins.py +1644 -0
  992. venv/Lib/site-packages/pygments/lexers/_cl_builtins.py +231 -0
  993. venv/Lib/site-packages/pygments/lexers/_cocoa_builtins.py +75 -0
  994. venv/Lib/site-packages/pygments/lexers/_csound_builtins.py +1780 -0
  995. venv/Lib/site-packages/pygments/lexers/_css_builtins.py +558 -0
  996. venv/Lib/site-packages/pygments/lexers/_googlesql_builtins.py +918 -0
  997. venv/Lib/site-packages/pygments/lexers/_julia_builtins.py +411 -0
  998. venv/Lib/site-packages/pygments/lexers/_lasso_builtins.py +5326 -0
  999. venv/Lib/site-packages/pygments/lexers/_lilypond_builtins.py +5184 -0
  1000. venv/Lib/site-packages/pygments/lexers/_lua_builtins.py +285 -0
  1001. venv/Lib/site-packages/pygments/lexers/_luau_builtins.py +62 -0
  1002. venv/Lib/site-packages/pygments/lexers/_mapping.py +603 -0
  1003. venv/Lib/site-packages/pygments/lexers/_mql_builtins.py +1171 -0
  1004. venv/Lib/site-packages/pygments/lexers/_mysql_builtins.py +1384 -0
  1005. venv/Lib/site-packages/pygments/lexers/_openedge_builtins.py +2600 -0
  1006. venv/Lib/site-packages/pygments/lexers/_php_builtins.py +3328 -0
  1007. venv/Lib/site-packages/pygments/lexers/_postgres_builtins.py +739 -0
  1008. venv/Lib/site-packages/pygments/lexers/_qlik_builtins.py +666 -0
  1009. venv/Lib/site-packages/pygments/lexers/_scheme_builtins.py +1609 -0
  1010. venv/Lib/site-packages/pygments/lexers/_scilab_builtins.py +3093 -0
  1011. venv/Lib/site-packages/pygments/lexers/_sourcemod_builtins.py +1151 -0
  1012. venv/Lib/site-packages/pygments/lexers/_sql_builtins.py +106 -0
  1013. venv/Lib/site-packages/pygments/lexers/_stan_builtins.py +761 -0
  1014. venv/Lib/site-packages/pygments/lexers/_stata_builtins.py +457 -0
  1015. venv/Lib/site-packages/pygments/lexers/_tsql_builtins.py +1003 -0
  1016. venv/Lib/site-packages/pygments/lexers/_usd_builtins.py +112 -0
  1017. venv/Lib/site-packages/pygments/lexers/_vbscript_builtins.py +279 -0
  1018. venv/Lib/site-packages/pygments/lexers/_vim_builtins.py +1938 -0
  1019. venv/Lib/site-packages/pygments/lexers/actionscript.py +243 -0
  1020. venv/Lib/site-packages/pygments/lexers/ada.py +144 -0
  1021. venv/Lib/site-packages/pygments/lexers/agile.py +25 -0
  1022. venv/Lib/site-packages/pygments/lexers/algebra.py +300 -0
  1023. venv/Lib/site-packages/pygments/lexers/ambient.py +75 -0
  1024. venv/Lib/site-packages/pygments/lexers/amdgpu.py +54 -0
  1025. venv/Lib/site-packages/pygments/lexers/ampl.py +87 -0
  1026. venv/Lib/site-packages/pygments/lexers/apdlexer.py +593 -0
  1027. venv/Lib/site-packages/pygments/lexers/apl.py +103 -0
  1028. venv/Lib/site-packages/pygments/lexers/archetype.py +315 -0
  1029. venv/Lib/site-packages/pygments/lexers/arrow.py +116 -0
  1030. venv/Lib/site-packages/pygments/lexers/arturo.py +249 -0
  1031. venv/Lib/site-packages/pygments/lexers/asc.py +55 -0
  1032. venv/Lib/site-packages/pygments/lexers/asm.py +1058 -0
  1033. venv/Lib/site-packages/pygments/lexers/asn1.py +178 -0
  1034. venv/Lib/site-packages/pygments/lexers/automation.py +379 -0
  1035. venv/Lib/site-packages/pygments/lexers/bare.py +101 -0
  1036. venv/Lib/site-packages/pygments/lexers/basic.py +656 -0
  1037. venv/Lib/site-packages/pygments/lexers/bdd.py +57 -0
  1038. venv/Lib/site-packages/pygments/lexers/berry.py +99 -0
  1039. venv/Lib/site-packages/pygments/lexers/bibtex.py +159 -0
  1040. venv/Lib/site-packages/pygments/lexers/blueprint.py +173 -0
  1041. venv/Lib/site-packages/pygments/lexers/boa.py +97 -0
  1042. venv/Lib/site-packages/pygments/lexers/bqn.py +112 -0
  1043. venv/Lib/site-packages/pygments/lexers/business.py +625 -0
  1044. venv/Lib/site-packages/pygments/lexers/c_cpp.py +415 -0
  1045. venv/Lib/site-packages/pygments/lexers/c_like.py +738 -0
  1046. venv/Lib/site-packages/pygments/lexers/capnproto.py +74 -0
  1047. venv/Lib/site-packages/pygments/lexers/carbon.py +95 -0
  1048. venv/Lib/site-packages/pygments/lexers/cddl.py +172 -0
  1049. venv/Lib/site-packages/pygments/lexers/chapel.py +139 -0
  1050. venv/Lib/site-packages/pygments/lexers/clean.py +180 -0
  1051. venv/Lib/site-packages/pygments/lexers/codeql.py +80 -0
  1052. venv/Lib/site-packages/pygments/lexers/comal.py +81 -0
  1053. venv/Lib/site-packages/pygments/lexers/compiled.py +35 -0
  1054. venv/Lib/site-packages/pygments/lexers/configs.py +1433 -0
  1055. venv/Lib/site-packages/pygments/lexers/console.py +114 -0
  1056. venv/Lib/site-packages/pygments/lexers/cplint.py +43 -0
  1057. venv/Lib/site-packages/pygments/lexers/crystal.py +364 -0
  1058. venv/Lib/site-packages/pygments/lexers/csound.py +466 -0
  1059. venv/Lib/site-packages/pygments/lexers/css.py +632 -0
  1060. venv/Lib/site-packages/pygments/lexers/d.py +259 -0
  1061. venv/Lib/site-packages/pygments/lexers/dalvik.py +126 -0
  1062. venv/Lib/site-packages/pygments/lexers/data.py +763 -0
  1063. venv/Lib/site-packages/pygments/lexers/dax.py +135 -0
  1064. venv/Lib/site-packages/pygments/lexers/devicetree.py +120 -0
  1065. venv/Lib/site-packages/pygments/lexers/diff.py +169 -0
  1066. venv/Lib/site-packages/pygments/lexers/dns.py +109 -0
  1067. venv/Lib/site-packages/pygments/lexers/dotnet.py +873 -0
  1068. venv/Lib/site-packages/pygments/lexers/dsls.py +970 -0
  1069. venv/Lib/site-packages/pygments/lexers/dylan.py +279 -0
  1070. venv/Lib/site-packages/pygments/lexers/ecl.py +144 -0
  1071. venv/Lib/site-packages/pygments/lexers/eiffel.py +68 -0
  1072. venv/Lib/site-packages/pygments/lexers/elm.py +123 -0
  1073. venv/Lib/site-packages/pygments/lexers/elpi.py +201 -0
  1074. venv/Lib/site-packages/pygments/lexers/email.py +132 -0
  1075. venv/Lib/site-packages/pygments/lexers/erlang.py +526 -0
  1076. venv/Lib/site-packages/pygments/lexers/esoteric.py +300 -0
  1077. venv/Lib/site-packages/pygments/lexers/ezhil.py +76 -0
  1078. venv/Lib/site-packages/pygments/lexers/factor.py +363 -0
  1079. venv/Lib/site-packages/pygments/lexers/fantom.py +251 -0
  1080. venv/Lib/site-packages/pygments/lexers/felix.py +275 -0
  1081. venv/Lib/site-packages/pygments/lexers/fift.py +68 -0
  1082. venv/Lib/site-packages/pygments/lexers/floscript.py +81 -0
  1083. venv/Lib/site-packages/pygments/lexers/forth.py +178 -0
  1084. venv/Lib/site-packages/pygments/lexers/fortran.py +212 -0
  1085. venv/Lib/site-packages/pygments/lexers/foxpro.py +427 -0
  1086. venv/Lib/site-packages/pygments/lexers/freefem.py +893 -0
  1087. venv/Lib/site-packages/pygments/lexers/func.py +110 -0
  1088. venv/Lib/site-packages/pygments/lexers/functional.py +21 -0
  1089. venv/Lib/site-packages/pygments/lexers/futhark.py +105 -0
  1090. venv/Lib/site-packages/pygments/lexers/gcodelexer.py +35 -0
  1091. venv/Lib/site-packages/pygments/lexers/gdscript.py +189 -0
  1092. venv/Lib/site-packages/pygments/lexers/gleam.py +74 -0
  1093. venv/Lib/site-packages/pygments/lexers/go.py +97 -0
  1094. venv/Lib/site-packages/pygments/lexers/grammar_notation.py +262 -0
  1095. venv/Lib/site-packages/pygments/lexers/graph.py +108 -0
  1096. venv/Lib/site-packages/pygments/lexers/graphics.py +794 -0
  1097. venv/Lib/site-packages/pygments/lexers/graphql.py +176 -0
  1098. venv/Lib/site-packages/pygments/lexers/graphviz.py +58 -0
  1099. venv/Lib/site-packages/pygments/lexers/gsql.py +103 -0
  1100. venv/Lib/site-packages/pygments/lexers/hare.py +73 -0
  1101. venv/Lib/site-packages/pygments/lexers/haskell.py +867 -0
  1102. venv/Lib/site-packages/pygments/lexers/haxe.py +941 -0
  1103. venv/Lib/site-packages/pygments/lexers/hdl.py +466 -0
  1104. venv/Lib/site-packages/pygments/lexers/hexdump.py +102 -0
  1105. venv/Lib/site-packages/pygments/lexers/html.py +670 -0
  1106. venv/Lib/site-packages/pygments/lexers/idl.py +284 -0
  1107. venv/Lib/site-packages/pygments/lexers/igor.py +435 -0
  1108. venv/Lib/site-packages/pygments/lexers/inferno.py +95 -0
  1109. venv/Lib/site-packages/pygments/lexers/installers.py +352 -0
  1110. venv/Lib/site-packages/pygments/lexers/int_fiction.py +1370 -0
  1111. venv/Lib/site-packages/pygments/lexers/iolang.py +61 -0
  1112. venv/Lib/site-packages/pygments/lexers/j.py +151 -0
  1113. venv/Lib/site-packages/pygments/lexers/javascript.py +1591 -0
  1114. venv/Lib/site-packages/pygments/lexers/jmespath.py +69 -0
  1115. venv/Lib/site-packages/pygments/lexers/jslt.py +94 -0
  1116. venv/Lib/site-packages/pygments/lexers/json5.py +83 -0
  1117. venv/Lib/site-packages/pygments/lexers/jsonnet.py +169 -0
  1118. venv/Lib/site-packages/pygments/lexers/jsx.py +100 -0
  1119. venv/Lib/site-packages/pygments/lexers/julia.py +294 -0
  1120. venv/Lib/site-packages/pygments/lexers/jvm.py +1807 -0
  1121. venv/Lib/site-packages/pygments/lexers/kuin.py +332 -0
  1122. venv/Lib/site-packages/pygments/lexers/kusto.py +93 -0
  1123. venv/Lib/site-packages/pygments/lexers/ldap.py +155 -0
  1124. venv/Lib/site-packages/pygments/lexers/lean.py +241 -0
  1125. venv/Lib/site-packages/pygments/lexers/lilypond.py +225 -0
  1126. venv/Lib/site-packages/pygments/lexers/lisp.py +3152 -0
  1127. venv/Lib/site-packages/pygments/lexers/macaulay2.py +1847 -0
  1128. venv/Lib/site-packages/pygments/lexers/make.py +212 -0
  1129. venv/Lib/site-packages/pygments/lexers/maple.py +291 -0
  1130. venv/Lib/site-packages/pygments/lexers/markup.py +1659 -0
  1131. venv/Lib/site-packages/pygments/lexers/math.py +21 -0
  1132. venv/Lib/site-packages/pygments/lexers/matlab.py +3307 -0
  1133. venv/Lib/site-packages/pygments/lexers/maxima.py +84 -0
  1134. venv/Lib/site-packages/pygments/lexers/meson.py +139 -0
  1135. venv/Lib/site-packages/pygments/lexers/mime.py +210 -0
  1136. venv/Lib/site-packages/pygments/lexers/minecraft.py +392 -0
  1137. venv/Lib/site-packages/pygments/lexers/mips.py +130 -0
  1138. venv/Lib/site-packages/pygments/lexers/ml.py +958 -0
  1139. venv/Lib/site-packages/pygments/lexers/modeling.py +368 -0
  1140. venv/Lib/site-packages/pygments/lexers/modula2.py +1579 -0
  1141. venv/Lib/site-packages/pygments/lexers/mojo.py +707 -0
  1142. venv/Lib/site-packages/pygments/lexers/monte.py +203 -0
  1143. venv/Lib/site-packages/pygments/lexers/mosel.py +447 -0
  1144. venv/Lib/site-packages/pygments/lexers/ncl.py +894 -0
  1145. venv/Lib/site-packages/pygments/lexers/nimrod.py +199 -0
  1146. venv/Lib/site-packages/pygments/lexers/nit.py +63 -0
  1147. venv/Lib/site-packages/pygments/lexers/nix.py +144 -0
  1148. venv/Lib/site-packages/pygments/lexers/numbair.py +63 -0
  1149. venv/Lib/site-packages/pygments/lexers/oberon.py +120 -0
  1150. venv/Lib/site-packages/pygments/lexers/objective.py +513 -0
  1151. venv/Lib/site-packages/pygments/lexers/ooc.py +84 -0
  1152. venv/Lib/site-packages/pygments/lexers/openscad.py +96 -0
  1153. venv/Lib/site-packages/pygments/lexers/other.py +41 -0
  1154. venv/Lib/site-packages/pygments/lexers/parasail.py +78 -0
  1155. venv/Lib/site-packages/pygments/lexers/parsers.py +798 -0
  1156. venv/Lib/site-packages/pygments/lexers/pascal.py +644 -0
  1157. venv/Lib/site-packages/pygments/lexers/pawn.py +202 -0
  1158. venv/Lib/site-packages/pygments/lexers/pddl.py +82 -0
  1159. venv/Lib/site-packages/pygments/lexers/perl.py +733 -0
  1160. venv/Lib/site-packages/pygments/lexers/phix.py +363 -0
  1161. venv/Lib/site-packages/pygments/lexers/php.py +335 -0
  1162. venv/Lib/site-packages/pygments/lexers/pointless.py +70 -0
  1163. venv/Lib/site-packages/pygments/lexers/pony.py +93 -0
  1164. venv/Lib/site-packages/pygments/lexers/praat.py +303 -0
  1165. venv/Lib/site-packages/pygments/lexers/procfile.py +41 -0
  1166. venv/Lib/site-packages/pygments/lexers/prolog.py +318 -0
  1167. venv/Lib/site-packages/pygments/lexers/promql.py +176 -0
  1168. venv/Lib/site-packages/pygments/lexers/prql.py +251 -0
  1169. venv/Lib/site-packages/pygments/lexers/ptx.py +119 -0
  1170. venv/Lib/site-packages/pygments/lexers/python.py +1204 -0
  1171. venv/Lib/site-packages/pygments/lexers/q.py +187 -0
  1172. venv/Lib/site-packages/pygments/lexers/qlik.py +117 -0
  1173. venv/Lib/site-packages/pygments/lexers/qvt.py +153 -0
  1174. venv/Lib/site-packages/pygments/lexers/r.py +196 -0
  1175. venv/Lib/site-packages/pygments/lexers/rdf.py +468 -0
  1176. venv/Lib/site-packages/pygments/lexers/rebol.py +419 -0
  1177. venv/Lib/site-packages/pygments/lexers/rego.py +57 -0
  1178. venv/Lib/site-packages/pygments/lexers/rell.py +68 -0
  1179. venv/Lib/site-packages/pygments/lexers/resource.py +83 -0
  1180. venv/Lib/site-packages/pygments/lexers/ride.py +138 -0
  1181. venv/Lib/site-packages/pygments/lexers/rita.py +42 -0
  1182. venv/Lib/site-packages/pygments/lexers/rnc.py +66 -0
  1183. venv/Lib/site-packages/pygments/lexers/roboconf.py +81 -0
  1184. venv/Lib/site-packages/pygments/lexers/robotframework.py +551 -0
  1185. venv/Lib/site-packages/pygments/lexers/ruby.py +518 -0
  1186. venv/Lib/site-packages/pygments/lexers/rust.py +222 -0
  1187. venv/Lib/site-packages/pygments/lexers/sas.py +227 -0
  1188. venv/Lib/site-packages/pygments/lexers/savi.py +171 -0
  1189. venv/Lib/site-packages/pygments/lexers/scdoc.py +85 -0
  1190. venv/Lib/site-packages/pygments/lexers/scripting.py +1638 -0
  1191. venv/Lib/site-packages/pygments/lexers/sgf.py +59 -0
  1192. venv/Lib/site-packages/pygments/lexers/shell.py +902 -0
  1193. venv/Lib/site-packages/pygments/lexers/sieve.py +78 -0
  1194. venv/Lib/site-packages/pygments/lexers/slash.py +183 -0
  1195. venv/Lib/site-packages/pygments/lexers/smalltalk.py +194 -0
  1196. venv/Lib/site-packages/pygments/lexers/smithy.py +77 -0
  1197. venv/Lib/site-packages/pygments/lexers/smv.py +78 -0
  1198. venv/Lib/site-packages/pygments/lexers/snobol.py +82 -0
  1199. venv/Lib/site-packages/pygments/lexers/solidity.py +87 -0
  1200. venv/Lib/site-packages/pygments/lexers/soong.py +78 -0
  1201. venv/Lib/site-packages/pygments/lexers/sophia.py +102 -0
  1202. venv/Lib/site-packages/pygments/lexers/special.py +122 -0
  1203. venv/Lib/site-packages/pygments/lexers/spice.py +70 -0
  1204. venv/Lib/site-packages/pygments/lexers/sql.py +1111 -0
  1205. venv/Lib/site-packages/pygments/lexers/srcinfo.py +62 -0
  1206. venv/Lib/site-packages/pygments/lexers/stata.py +170 -0
  1207. venv/Lib/site-packages/pygments/lexers/supercollider.py +94 -0
  1208. venv/Lib/site-packages/pygments/lexers/tablegen.py +177 -0
  1209. venv/Lib/site-packages/pygments/lexers/tact.py +303 -0
  1210. venv/Lib/site-packages/pygments/lexers/tal.py +77 -0
  1211. venv/Lib/site-packages/pygments/lexers/tcl.py +148 -0
  1212. venv/Lib/site-packages/pygments/lexers/teal.py +88 -0
  1213. venv/Lib/site-packages/pygments/lexers/templates.py +2355 -0
  1214. venv/Lib/site-packages/pygments/lexers/teraterm.py +335 -0
  1215. venv/Lib/site-packages/pygments/lexers/testing.py +209 -0
  1216. venv/Lib/site-packages/pygments/lexers/text.py +27 -0
  1217. venv/Lib/site-packages/pygments/lexers/textedit.py +205 -0
  1218. venv/Lib/site-packages/pygments/lexers/textfmts.py +436 -0
  1219. venv/Lib/site-packages/pygments/lexers/theorem.py +410 -0
  1220. venv/Lib/site-packages/pygments/lexers/thingsdb.py +143 -0
  1221. venv/Lib/site-packages/pygments/lexers/tlb.py +59 -0
  1222. venv/Lib/site-packages/pygments/lexers/tls.py +54 -0
  1223. venv/Lib/site-packages/pygments/lexers/tnt.py +270 -0
  1224. venv/Lib/site-packages/pygments/lexers/trafficscript.py +51 -0
  1225. venv/Lib/site-packages/pygments/lexers/typoscript.py +216 -0
  1226. venv/Lib/site-packages/pygments/lexers/typst.py +160 -0
  1227. venv/Lib/site-packages/pygments/lexers/ul4.py +309 -0
  1228. venv/Lib/site-packages/pygments/lexers/unicon.py +413 -0
  1229. venv/Lib/site-packages/pygments/lexers/urbi.py +145 -0
  1230. venv/Lib/site-packages/pygments/lexers/usd.py +85 -0
  1231. venv/Lib/site-packages/pygments/lexers/varnish.py +189 -0
  1232. venv/Lib/site-packages/pygments/lexers/verification.py +113 -0
  1233. venv/Lib/site-packages/pygments/lexers/verifpal.py +65 -0
  1234. venv/Lib/site-packages/pygments/lexers/vip.py +150 -0
  1235. venv/Lib/site-packages/pygments/lexers/vyper.py +140 -0
  1236. venv/Lib/site-packages/pygments/lexers/web.py +24 -0
  1237. venv/Lib/site-packages/pygments/lexers/webassembly.py +119 -0
  1238. venv/Lib/site-packages/pygments/lexers/webidl.py +298 -0
  1239. venv/Lib/site-packages/pygments/lexers/webmisc.py +1006 -0
  1240. venv/Lib/site-packages/pygments/lexers/wgsl.py +406 -0
  1241. venv/Lib/site-packages/pygments/lexers/whiley.py +115 -0
  1242. venv/Lib/site-packages/pygments/lexers/wowtoc.py +120 -0
  1243. venv/Lib/site-packages/pygments/lexers/wren.py +98 -0
  1244. venv/Lib/site-packages/pygments/lexers/x10.py +66 -0
  1245. venv/Lib/site-packages/pygments/lexers/xorg.py +38 -0
  1246. venv/Lib/site-packages/pygments/lexers/yang.py +103 -0
  1247. venv/Lib/site-packages/pygments/lexers/yara.py +69 -0
  1248. venv/Lib/site-packages/pygments/lexers/zig.py +125 -0
  1249. venv/Lib/site-packages/pygments/modeline.py +43 -0
  1250. venv/Lib/site-packages/pygments/plugin.py +74 -0
  1251. venv/Lib/site-packages/pygments/regexopt.py +102 -0
  1252. venv/Lib/site-packages/pygments/scanner.py +104 -0
  1253. venv/Lib/site-packages/pygments/sphinxext.py +247 -0
  1254. venv/Lib/site-packages/pygments/style.py +203 -0
  1255. venv/Lib/site-packages/pygments/styles/__init__.py +61 -0
  1256. venv/Lib/site-packages/pygments/styles/_mapping.py +54 -0
  1257. venv/Lib/site-packages/pygments/styles/abap.py +32 -0
  1258. venv/Lib/site-packages/pygments/styles/algol.py +65 -0
  1259. venv/Lib/site-packages/pygments/styles/algol_nu.py +65 -0
  1260. venv/Lib/site-packages/pygments/styles/arduino.py +100 -0
  1261. venv/Lib/site-packages/pygments/styles/autumn.py +67 -0
  1262. venv/Lib/site-packages/pygments/styles/borland.py +53 -0
  1263. venv/Lib/site-packages/pygments/styles/bw.py +52 -0
  1264. venv/Lib/site-packages/pygments/styles/coffee.py +80 -0
  1265. venv/Lib/site-packages/pygments/styles/colorful.py +83 -0
  1266. venv/Lib/site-packages/pygments/styles/default.py +76 -0
  1267. venv/Lib/site-packages/pygments/styles/dracula.py +90 -0
  1268. venv/Lib/site-packages/pygments/styles/emacs.py +75 -0
  1269. venv/Lib/site-packages/pygments/styles/friendly.py +76 -0
  1270. venv/Lib/site-packages/pygments/styles/friendly_grayscale.py +80 -0
  1271. venv/Lib/site-packages/pygments/styles/fruity.py +47 -0
  1272. venv/Lib/site-packages/pygments/styles/gh_dark.py +113 -0
  1273. venv/Lib/site-packages/pygments/styles/gruvbox.py +118 -0
  1274. venv/Lib/site-packages/pygments/styles/igor.py +32 -0
  1275. venv/Lib/site-packages/pygments/styles/inkpot.py +72 -0
  1276. venv/Lib/site-packages/pygments/styles/lightbulb.py +110 -0
  1277. venv/Lib/site-packages/pygments/styles/lilypond.py +62 -0
  1278. venv/Lib/site-packages/pygments/styles/lovelace.py +100 -0
  1279. venv/Lib/site-packages/pygments/styles/manni.py +79 -0
  1280. venv/Lib/site-packages/pygments/styles/material.py +124 -0
  1281. venv/Lib/site-packages/pygments/styles/monokai.py +112 -0
  1282. venv/Lib/site-packages/pygments/styles/murphy.py +82 -0
  1283. venv/Lib/site-packages/pygments/styles/native.py +70 -0
  1284. venv/Lib/site-packages/pygments/styles/nord.py +156 -0
  1285. venv/Lib/site-packages/pygments/styles/onedark.py +73 -0
  1286. venv/Lib/site-packages/pygments/styles/paraiso_dark.py +124 -0
  1287. venv/Lib/site-packages/pygments/styles/paraiso_light.py +124 -0
  1288. venv/Lib/site-packages/pygments/styles/pastie.py +78 -0
  1289. venv/Lib/site-packages/pygments/styles/perldoc.py +73 -0
  1290. venv/Lib/site-packages/pygments/styles/rainbow_dash.py +95 -0
  1291. venv/Lib/site-packages/pygments/styles/rrt.py +54 -0
  1292. venv/Lib/site-packages/pygments/styles/sas.py +46 -0
  1293. venv/Lib/site-packages/pygments/styles/solarized.py +144 -0
  1294. venv/Lib/site-packages/pygments/styles/staroffice.py +31 -0
  1295. venv/Lib/site-packages/pygments/styles/stata_dark.py +42 -0
  1296. venv/Lib/site-packages/pygments/styles/stata_light.py +42 -0
  1297. venv/Lib/site-packages/pygments/styles/tango.py +143 -0
  1298. venv/Lib/site-packages/pygments/styles/trac.py +66 -0
  1299. venv/Lib/site-packages/pygments/styles/vim.py +67 -0
  1300. venv/Lib/site-packages/pygments/styles/vs.py +41 -0
  1301. venv/Lib/site-packages/pygments/styles/xcode.py +53 -0
  1302. venv/Lib/site-packages/pygments/styles/zenburn.py +83 -0
  1303. venv/Lib/site-packages/pygments/token.py +214 -0
  1304. venv/Lib/site-packages/pygments/unistring.py +153 -0
  1305. venv/Lib/site-packages/pygments/util.py +324 -0
  1306. venv/Lib/site-packages/pyproject_hooks/__init__.py +31 -0
  1307. venv/Lib/site-packages/pyproject_hooks/_impl.py +410 -0
  1308. venv/Lib/site-packages/pyproject_hooks/_in_process/__init__.py +21 -0
  1309. venv/Lib/site-packages/pyproject_hooks/_in_process/_in_process.py +389 -0
  1310. venv/Lib/site-packages/pyproject_hooks/py.typed +0 -0
  1311. venv/Lib/site-packages/pytest/__init__.py +186 -0
  1312. venv/Lib/site-packages/pytest/__main__.py +9 -0
  1313. venv/Lib/site-packages/pytest/py.typed +0 -0
  1314. venv/Lib/site-packages/readme_renderer/__init__.py +13 -0
  1315. venv/Lib/site-packages/readme_renderer/__main__.py +66 -0
  1316. venv/Lib/site-packages/readme_renderer/clean.py +89 -0
  1317. venv/Lib/site-packages/readme_renderer/markdown.py +123 -0
  1318. venv/Lib/site-packages/readme_renderer/py.typed +0 -0
  1319. venv/Lib/site-packages/readme_renderer/rst.py +135 -0
  1320. venv/Lib/site-packages/readme_renderer/txt.py +24 -0
  1321. venv/Lib/site-packages/requests/__init__.py +183 -0
  1322. venv/Lib/site-packages/requests/__version__.py +14 -0
  1323. venv/Lib/site-packages/requests/_internal_utils.py +51 -0
  1324. venv/Lib/site-packages/requests/adapters.py +697 -0
  1325. venv/Lib/site-packages/requests/api.py +157 -0
  1326. venv/Lib/site-packages/requests/auth.py +314 -0
  1327. venv/Lib/site-packages/requests/certs.py +18 -0
  1328. venv/Lib/site-packages/requests/compat.py +106 -0
  1329. venv/Lib/site-packages/requests/cookies.py +561 -0
  1330. venv/Lib/site-packages/requests/exceptions.py +152 -0
  1331. venv/Lib/site-packages/requests/help.py +131 -0
  1332. venv/Lib/site-packages/requests/hooks.py +34 -0
  1333. venv/Lib/site-packages/requests/models.py +1041 -0
  1334. venv/Lib/site-packages/requests/packages.py +23 -0
  1335. venv/Lib/site-packages/requests/sessions.py +834 -0
  1336. venv/Lib/site-packages/requests/status_codes.py +128 -0
  1337. venv/Lib/site-packages/requests/structures.py +99 -0
  1338. venv/Lib/site-packages/requests/utils.py +1083 -0
  1339. venv/Lib/site-packages/requests_toolbelt/__init__.py +34 -0
  1340. venv/Lib/site-packages/requests_toolbelt/_compat.py +302 -0
  1341. venv/Lib/site-packages/requests_toolbelt/adapters/__init__.py +15 -0
  1342. venv/Lib/site-packages/requests_toolbelt/adapters/appengine.py +206 -0
  1343. venv/Lib/site-packages/requests_toolbelt/adapters/fingerprint.py +48 -0
  1344. venv/Lib/site-packages/requests_toolbelt/adapters/host_header_ssl.py +43 -0
  1345. venv/Lib/site-packages/requests_toolbelt/adapters/socket_options.py +129 -0
  1346. venv/Lib/site-packages/requests_toolbelt/adapters/source.py +67 -0
  1347. venv/Lib/site-packages/requests_toolbelt/adapters/ssl.py +66 -0
  1348. venv/Lib/site-packages/requests_toolbelt/adapters/x509.py +196 -0
  1349. venv/Lib/site-packages/requests_toolbelt/auth/__init__.py +0 -0
  1350. venv/Lib/site-packages/requests_toolbelt/auth/_digest_auth_compat.py +29 -0
  1351. venv/Lib/site-packages/requests_toolbelt/auth/guess.py +146 -0
  1352. venv/Lib/site-packages/requests_toolbelt/auth/handler.py +142 -0
  1353. venv/Lib/site-packages/requests_toolbelt/auth/http_proxy_digest.py +103 -0
  1354. venv/Lib/site-packages/requests_toolbelt/cookies/__init__.py +0 -0
  1355. venv/Lib/site-packages/requests_toolbelt/cookies/forgetful.py +7 -0
  1356. venv/Lib/site-packages/requests_toolbelt/downloadutils/__init__.py +0 -0
  1357. venv/Lib/site-packages/requests_toolbelt/downloadutils/stream.py +176 -0
  1358. venv/Lib/site-packages/requests_toolbelt/downloadutils/tee.py +123 -0
  1359. venv/Lib/site-packages/requests_toolbelt/exceptions.py +25 -0
  1360. venv/Lib/site-packages/requests_toolbelt/multipart/__init__.py +31 -0
  1361. venv/Lib/site-packages/requests_toolbelt/multipart/decoder.py +156 -0
  1362. venv/Lib/site-packages/requests_toolbelt/multipart/encoder.py +655 -0
  1363. venv/Lib/site-packages/requests_toolbelt/sessions.py +89 -0
  1364. venv/Lib/site-packages/requests_toolbelt/streaming_iterator.py +116 -0
  1365. venv/Lib/site-packages/requests_toolbelt/threaded/__init__.py +97 -0
  1366. venv/Lib/site-packages/requests_toolbelt/threaded/pool.py +211 -0
  1367. venv/Lib/site-packages/requests_toolbelt/threaded/thread.py +53 -0
  1368. venv/Lib/site-packages/requests_toolbelt/utils/__init__.py +0 -0
  1369. venv/Lib/site-packages/requests_toolbelt/utils/deprecated.py +91 -0
  1370. venv/Lib/site-packages/requests_toolbelt/utils/dump.py +198 -0
  1371. venv/Lib/site-packages/requests_toolbelt/utils/formdata.py +108 -0
  1372. venv/Lib/site-packages/requests_toolbelt/utils/user_agent.py +143 -0
  1373. venv/Lib/site-packages/rfc3986/__init__.py +53 -0
  1374. venv/Lib/site-packages/rfc3986/_mixin.py +373 -0
  1375. venv/Lib/site-packages/rfc3986/abnf_regexp.py +275 -0
  1376. venv/Lib/site-packages/rfc3986/api.py +104 -0
  1377. venv/Lib/site-packages/rfc3986/builder.py +388 -0
  1378. venv/Lib/site-packages/rfc3986/compat.py +59 -0
  1379. venv/Lib/site-packages/rfc3986/exceptions.py +120 -0
  1380. venv/Lib/site-packages/rfc3986/iri.py +161 -0
  1381. venv/Lib/site-packages/rfc3986/misc.py +131 -0
  1382. venv/Lib/site-packages/rfc3986/normalizers.py +171 -0
  1383. venv/Lib/site-packages/rfc3986/parseresult.py +474 -0
  1384. venv/Lib/site-packages/rfc3986/uri.py +160 -0
  1385. venv/Lib/site-packages/rfc3986/validators.py +440 -0
  1386. venv/Lib/site-packages/rich/__init__.py +177 -0
  1387. venv/Lib/site-packages/rich/__main__.py +245 -0
  1388. venv/Lib/site-packages/rich/_emoji_codes.py +3610 -0
  1389. venv/Lib/site-packages/rich/_emoji_replace.py +31 -0
  1390. venv/Lib/site-packages/rich/_export_format.py +76 -0
  1391. venv/Lib/site-packages/rich/_extension.py +10 -0
  1392. venv/Lib/site-packages/rich/_fileno.py +24 -0
  1393. venv/Lib/site-packages/rich/_inspect.py +272 -0
  1394. venv/Lib/site-packages/rich/_log_render.py +94 -0
  1395. venv/Lib/site-packages/rich/_loop.py +43 -0
  1396. venv/Lib/site-packages/rich/_null_file.py +69 -0
  1397. venv/Lib/site-packages/rich/_palettes.py +309 -0
  1398. venv/Lib/site-packages/rich/_pick.py +17 -0
  1399. venv/Lib/site-packages/rich/_ratio.py +153 -0
  1400. venv/Lib/site-packages/rich/_spinners.py +482 -0
  1401. venv/Lib/site-packages/rich/_stack.py +16 -0
  1402. venv/Lib/site-packages/rich/_timer.py +19 -0
  1403. venv/Lib/site-packages/rich/_unicode_data/__init__.py +93 -0
  1404. venv/Lib/site-packages/rich/_unicode_data/_versions.py +23 -0
  1405. venv/Lib/site-packages/rich/_unicode_data/unicode10-0-0.py +611 -0
  1406. venv/Lib/site-packages/rich/_unicode_data/unicode11-0-0.py +625 -0
  1407. venv/Lib/site-packages/rich/_unicode_data/unicode12-0-0.py +637 -0
  1408. venv/Lib/site-packages/rich/_unicode_data/unicode12-1-0.py +636 -0
  1409. venv/Lib/site-packages/rich/_unicode_data/unicode13-0-0.py +648 -0
  1410. venv/Lib/site-packages/rich/_unicode_data/unicode14-0-0.py +661 -0
  1411. venv/Lib/site-packages/rich/_unicode_data/unicode15-0-0.py +671 -0
  1412. venv/Lib/site-packages/rich/_unicode_data/unicode15-1-0.py +670 -0
  1413. venv/Lib/site-packages/rich/_unicode_data/unicode16-0-0.py +683 -0
  1414. venv/Lib/site-packages/rich/_unicode_data/unicode17-0-0.py +691 -0
  1415. venv/Lib/site-packages/rich/_unicode_data/unicode4-1-0.py +425 -0
  1416. venv/Lib/site-packages/rich/_unicode_data/unicode5-0-0.py +430 -0
  1417. venv/Lib/site-packages/rich/_unicode_data/unicode5-1-0.py +433 -0
  1418. venv/Lib/site-packages/rich/_unicode_data/unicode5-2-0.py +461 -0
  1419. venv/Lib/site-packages/rich/_unicode_data/unicode6-0-0.py +469 -0
  1420. venv/Lib/site-packages/rich/_unicode_data/unicode6-1-0.py +480 -0
  1421. venv/Lib/site-packages/rich/_unicode_data/unicode6-2-0.py +480 -0
  1422. venv/Lib/site-packages/rich/_unicode_data/unicode6-3-0.py +481 -0
  1423. venv/Lib/site-packages/rich/_unicode_data/unicode7-0-0.py +507 -0
  1424. venv/Lib/site-packages/rich/_unicode_data/unicode8-0-0.py +515 -0
  1425. venv/Lib/site-packages/rich/_unicode_data/unicode9-0-0.py +598 -0
  1426. venv/Lib/site-packages/rich/_win32_console.py +661 -0
  1427. venv/Lib/site-packages/rich/_windows.py +71 -0
  1428. venv/Lib/site-packages/rich/_windows_renderer.py +56 -0
  1429. venv/Lib/site-packages/rich/_wrap.py +93 -0
  1430. venv/Lib/site-packages/rich/abc.py +33 -0
  1431. venv/Lib/site-packages/rich/align.py +320 -0
  1432. venv/Lib/site-packages/rich/ansi.py +241 -0
  1433. venv/Lib/site-packages/rich/bar.py +93 -0
  1434. venv/Lib/site-packages/rich/box.py +474 -0
  1435. venv/Lib/site-packages/rich/cells.py +352 -0
  1436. venv/Lib/site-packages/rich/color.py +621 -0
  1437. venv/Lib/site-packages/rich/color_triplet.py +38 -0
  1438. venv/Lib/site-packages/rich/columns.py +187 -0
  1439. venv/Lib/site-packages/rich/console.py +2698 -0
  1440. venv/Lib/site-packages/rich/constrain.py +37 -0
  1441. venv/Lib/site-packages/rich/containers.py +167 -0
  1442. venv/Lib/site-packages/rich/control.py +219 -0
  1443. venv/Lib/site-packages/rich/default_styles.py +196 -0
  1444. venv/Lib/site-packages/rich/diagnose.py +39 -0
  1445. venv/Lib/site-packages/rich/emoji.py +93 -0
  1446. venv/Lib/site-packages/rich/errors.py +34 -0
  1447. venv/Lib/site-packages/rich/file_proxy.py +60 -0
  1448. venv/Lib/site-packages/rich/filesize.py +88 -0
  1449. venv/Lib/site-packages/rich/highlighter.py +232 -0
  1450. venv/Lib/site-packages/rich/json.py +139 -0
  1451. venv/Lib/site-packages/rich/jupyter.py +101 -0
  1452. venv/Lib/site-packages/rich/layout.py +442 -0
  1453. venv/Lib/site-packages/rich/live.py +404 -0
  1454. venv/Lib/site-packages/rich/live_render.py +116 -0
  1455. venv/Lib/site-packages/rich/logging.py +305 -0
  1456. venv/Lib/site-packages/rich/markdown.py +802 -0
  1457. venv/Lib/site-packages/rich/markup.py +251 -0
  1458. venv/Lib/site-packages/rich/measure.py +151 -0
  1459. venv/Lib/site-packages/rich/padding.py +141 -0
  1460. venv/Lib/site-packages/rich/pager.py +34 -0
  1461. venv/Lib/site-packages/rich/palette.py +100 -0
  1462. venv/Lib/site-packages/rich/panel.py +317 -0
  1463. venv/Lib/site-packages/rich/pretty.py +1016 -0
  1464. venv/Lib/site-packages/rich/progress.py +1716 -0
  1465. venv/Lib/site-packages/rich/progress_bar.py +223 -0
  1466. venv/Lib/site-packages/rich/prompt.py +400 -0
  1467. venv/Lib/site-packages/rich/protocol.py +41 -0
  1468. venv/Lib/site-packages/rich/py.typed +0 -0
  1469. venv/Lib/site-packages/rich/region.py +10 -0
  1470. venv/Lib/site-packages/rich/repr.py +150 -0
  1471. venv/Lib/site-packages/rich/rule.py +130 -0
  1472. venv/Lib/site-packages/rich/scope.py +92 -0
  1473. venv/Lib/site-packages/rich/screen.py +54 -0
  1474. venv/Lib/site-packages/rich/segment.py +780 -0
  1475. venv/Lib/site-packages/rich/spinner.py +132 -0
  1476. venv/Lib/site-packages/rich/status.py +131 -0
  1477. venv/Lib/site-packages/rich/style.py +796 -0
  1478. venv/Lib/site-packages/rich/styled.py +42 -0
  1479. venv/Lib/site-packages/rich/syntax.py +988 -0
  1480. venv/Lib/site-packages/rich/table.py +1015 -0
  1481. venv/Lib/site-packages/rich/terminal_theme.py +153 -0
  1482. venv/Lib/site-packages/rich/text.py +1363 -0
  1483. venv/Lib/site-packages/rich/theme.py +116 -0
  1484. venv/Lib/site-packages/rich/themes.py +5 -0
  1485. venv/Lib/site-packages/rich/traceback.py +924 -0
  1486. venv/Lib/site-packages/rich/tree.py +257 -0
  1487. venv/Lib/site-packages/twine/__init__.py +54 -0
  1488. venv/Lib/site-packages/twine/__main__.py +54 -0
  1489. venv/Lib/site-packages/twine/auth.py +307 -0
  1490. venv/Lib/site-packages/twine/cli.py +139 -0
  1491. venv/Lib/site-packages/twine/commands/__init__.py +93 -0
  1492. venv/Lib/site-packages/twine/commands/check.py +195 -0
  1493. venv/Lib/site-packages/twine/commands/register.py +87 -0
  1494. venv/Lib/site-packages/twine/commands/upload.py +253 -0
  1495. venv/Lib/site-packages/twine/distribution.py +8 -0
  1496. venv/Lib/site-packages/twine/exceptions.py +175 -0
  1497. venv/Lib/site-packages/twine/package.py +403 -0
  1498. venv/Lib/site-packages/twine/py.typed +0 -0
  1499. venv/Lib/site-packages/twine/repository.py +246 -0
  1500. venv/Lib/site-packages/twine/sdist.py +83 -0
  1501. venv/Lib/site-packages/twine/settings.py +360 -0
  1502. venv/Lib/site-packages/twine/utils.py +387 -0
  1503. venv/Lib/site-packages/twine/wheel.py +81 -0
  1504. venv/Lib/site-packages/typing_extensions.py +4317 -0
  1505. venv/Lib/site-packages/typing_inspection/__init__.py +0 -0
  1506. venv/Lib/site-packages/typing_inspection/introspection.py +587 -0
  1507. venv/Lib/site-packages/typing_inspection/py.typed +0 -0
  1508. venv/Lib/site-packages/typing_inspection/typing_objects.py +607 -0
  1509. venv/Lib/site-packages/typing_inspection/typing_objects.pyi +417 -0
  1510. venv/Lib/site-packages/urllib3/__init__.py +211 -0
  1511. venv/Lib/site-packages/urllib3/_base_connection.py +167 -0
  1512. venv/Lib/site-packages/urllib3/_collections.py +486 -0
  1513. venv/Lib/site-packages/urllib3/_request_methods.py +278 -0
  1514. venv/Lib/site-packages/urllib3/_version.py +24 -0
  1515. venv/Lib/site-packages/urllib3/connection.py +1099 -0
  1516. venv/Lib/site-packages/urllib3/connectionpool.py +1191 -0
  1517. venv/Lib/site-packages/urllib3/contrib/__init__.py +0 -0
  1518. venv/Lib/site-packages/urllib3/contrib/emscripten/__init__.py +17 -0
  1519. venv/Lib/site-packages/urllib3/contrib/emscripten/connection.py +260 -0
  1520. venv/Lib/site-packages/urllib3/contrib/emscripten/fetch.py +726 -0
  1521. venv/Lib/site-packages/urllib3/contrib/emscripten/request.py +22 -0
  1522. venv/Lib/site-packages/urllib3/contrib/emscripten/response.py +281 -0
  1523. venv/Lib/site-packages/urllib3/contrib/pyopenssl.py +563 -0
  1524. venv/Lib/site-packages/urllib3/contrib/socks.py +228 -0
  1525. venv/Lib/site-packages/urllib3/exceptions.py +335 -0
  1526. venv/Lib/site-packages/urllib3/fields.py +341 -0
  1527. venv/Lib/site-packages/urllib3/filepost.py +89 -0
  1528. venv/Lib/site-packages/urllib3/http2/__init__.py +53 -0
  1529. venv/Lib/site-packages/urllib3/http2/connection.py +356 -0
  1530. venv/Lib/site-packages/urllib3/http2/probe.py +87 -0
  1531. venv/Lib/site-packages/urllib3/poolmanager.py +653 -0
  1532. venv/Lib/site-packages/urllib3/py.typed +2 -0
  1533. venv/Lib/site-packages/urllib3/response.py +1493 -0
  1534. venv/Lib/site-packages/urllib3/util/__init__.py +42 -0
  1535. venv/Lib/site-packages/urllib3/util/connection.py +137 -0
  1536. venv/Lib/site-packages/urllib3/util/proxy.py +43 -0
  1537. venv/Lib/site-packages/urllib3/util/request.py +263 -0
  1538. venv/Lib/site-packages/urllib3/util/response.py +101 -0
  1539. venv/Lib/site-packages/urllib3/util/retry.py +557 -0
  1540. venv/Lib/site-packages/urllib3/util/ssl_.py +477 -0
  1541. venv/Lib/site-packages/urllib3/util/ssl_match_hostname.py +153 -0
  1542. venv/Lib/site-packages/urllib3/util/ssltransport.py +271 -0
  1543. venv/Lib/site-packages/urllib3/util/timeout.py +275 -0
  1544. venv/Lib/site-packages/urllib3/util/url.py +469 -0
  1545. venv/Lib/site-packages/urllib3/util/util.py +42 -0
  1546. venv/Lib/site-packages/urllib3/util/wait.py +124 -0
  1547. venv/Lib/site-packages/win32ctypes/__init__.py +8 -0
  1548. venv/Lib/site-packages/win32ctypes/core/__init__.py +60 -0
  1549. venv/Lib/site-packages/win32ctypes/core/_winerrors.py +9 -0
  1550. venv/Lib/site-packages/win32ctypes/core/cffi/__init__.py +11 -0
  1551. venv/Lib/site-packages/win32ctypes/core/cffi/_authentication.py +172 -0
  1552. venv/Lib/site-packages/win32ctypes/core/cffi/_common.py +29 -0
  1553. venv/Lib/site-packages/win32ctypes/core/cffi/_dll.py +30 -0
  1554. venv/Lib/site-packages/win32ctypes/core/cffi/_nl_support.py +18 -0
  1555. venv/Lib/site-packages/win32ctypes/core/cffi/_resource.py +132 -0
  1556. venv/Lib/site-packages/win32ctypes/core/cffi/_system_information.py +32 -0
  1557. venv/Lib/site-packages/win32ctypes/core/cffi/_time.py +18 -0
  1558. venv/Lib/site-packages/win32ctypes/core/cffi/_util.py +105 -0
  1559. venv/Lib/site-packages/win32ctypes/core/compat.py +10 -0
  1560. venv/Lib/site-packages/win32ctypes/core/ctypes/__init__.py +11 -0
  1561. venv/Lib/site-packages/win32ctypes/core/ctypes/_authentication.py +122 -0
  1562. venv/Lib/site-packages/win32ctypes/core/ctypes/_common.py +53 -0
  1563. venv/Lib/site-packages/win32ctypes/core/ctypes/_dll.py +21 -0
  1564. venv/Lib/site-packages/win32ctypes/core/ctypes/_nl_support.py +12 -0
  1565. venv/Lib/site-packages/win32ctypes/core/ctypes/_resource.py +148 -0
  1566. venv/Lib/site-packages/win32ctypes/core/ctypes/_system_information.py +36 -0
  1567. venv/Lib/site-packages/win32ctypes/core/ctypes/_time.py +15 -0
  1568. venv/Lib/site-packages/win32ctypes/core/ctypes/_util.py +78 -0
  1569. venv/Lib/site-packages/win32ctypes/pywin32/__init__.py +12 -0
  1570. venv/Lib/site-packages/win32ctypes/pywin32/pywintypes.py +67 -0
  1571. venv/Lib/site-packages/win32ctypes/pywin32/win32api.py +294 -0
  1572. venv/Lib/site-packages/win32ctypes/pywin32/win32cred.py +145 -0
  1573. venv/Lib/site-packages/win32ctypes/pywintypes.py +13 -0
  1574. venv/Lib/site-packages/win32ctypes/tests/__init__.py +21 -0
  1575. venv/Lib/site-packages/win32ctypes/tests/test_backends.py +36 -0
  1576. venv/Lib/site-packages/win32ctypes/tests/test_win32api.py +304 -0
  1577. venv/Lib/site-packages/win32ctypes/tests/test_win32cred.py +230 -0
  1578. venv/Lib/site-packages/win32ctypes/version.py +1 -0
  1579. venv/Lib/site-packages/win32ctypes/win32api.py +13 -0
  1580. venv/Lib/site-packages/win32ctypes/win32cred.py +13 -0
@@ -0,0 +1,3310 @@
1
+ """The types module contains custom types used by pydantic."""
2
+
3
+ from __future__ import annotations as _annotations
4
+
5
+ import base64
6
+ import dataclasses as _dataclasses
7
+ import re
8
+ from collections.abc import Hashable, Iterator
9
+ from datetime import date, datetime
10
+ from decimal import Decimal
11
+ from enum import Enum
12
+ from pathlib import Path
13
+ from re import Pattern
14
+ from types import ModuleType
15
+ from typing import (
16
+ TYPE_CHECKING,
17
+ Annotated,
18
+ Any,
19
+ Callable,
20
+ ClassVar,
21
+ Generic,
22
+ Literal,
23
+ TypeVar,
24
+ Union,
25
+ cast,
26
+ )
27
+ from uuid import UUID
28
+
29
+ import annotated_types
30
+ from annotated_types import BaseMetadata, MaxLen, MinLen
31
+ from pydantic_core import CoreSchema, PydanticCustomError, SchemaSerializer, core_schema
32
+ from typing_extensions import Protocol, TypeAlias, TypeAliasType, deprecated, get_args, get_origin
33
+
34
+ from ._internal import _fields, _internal_dataclass, _utils, _validators
35
+ from ._migration import getattr_migration
36
+ from .annotated_handlers import GetCoreSchemaHandler, GetJsonSchemaHandler
37
+ from .errors import PydanticUserError
38
+ from .json_schema import JsonSchemaValue
39
+ from .warnings import PydanticDeprecatedSince20
40
+
41
+ if TYPE_CHECKING:
42
+ from ._internal._core_metadata import CoreMetadata
43
+
44
+ __all__ = (
45
+ 'Strict',
46
+ 'StrictStr',
47
+ 'SocketPath',
48
+ 'conbytes',
49
+ 'conlist',
50
+ 'conset',
51
+ 'confrozenset',
52
+ 'constr',
53
+ 'ImportString',
54
+ 'conint',
55
+ 'PositiveInt',
56
+ 'NegativeInt',
57
+ 'NonNegativeInt',
58
+ 'NonPositiveInt',
59
+ 'confloat',
60
+ 'PositiveFloat',
61
+ 'NegativeFloat',
62
+ 'NonNegativeFloat',
63
+ 'NonPositiveFloat',
64
+ 'FiniteFloat',
65
+ 'condecimal',
66
+ 'UUID1',
67
+ 'UUID3',
68
+ 'UUID4',
69
+ 'UUID5',
70
+ 'UUID6',
71
+ 'UUID7',
72
+ 'UUID8',
73
+ 'FilePath',
74
+ 'DirectoryPath',
75
+ 'NewPath',
76
+ 'Json',
77
+ 'Secret',
78
+ 'SecretStr',
79
+ 'SecretBytes',
80
+ 'StrictBool',
81
+ 'StrictBytes',
82
+ 'StrictInt',
83
+ 'StrictFloat',
84
+ 'PaymentCardNumber',
85
+ 'ByteSize',
86
+ 'PastDate',
87
+ 'FutureDate',
88
+ 'PastDatetime',
89
+ 'FutureDatetime',
90
+ 'condate',
91
+ 'AwareDatetime',
92
+ 'NaiveDatetime',
93
+ 'AllowInfNan',
94
+ 'EncoderProtocol',
95
+ 'EncodedBytes',
96
+ 'EncodedStr',
97
+ 'Base64Encoder',
98
+ 'Base64Bytes',
99
+ 'Base64Str',
100
+ 'Base64UrlBytes',
101
+ 'Base64UrlStr',
102
+ 'GetPydanticSchema',
103
+ 'StringConstraints',
104
+ 'Tag',
105
+ 'Discriminator',
106
+ 'JsonValue',
107
+ 'OnErrorOmit',
108
+ 'FailFast',
109
+ )
110
+
111
+
112
+ T = TypeVar('T')
113
+
114
+
115
+ @_dataclasses.dataclass
116
+ class Strict(_fields.PydanticMetadata, BaseMetadata):
117
+ """!!! abstract "Usage Documentation"
118
+ [Strict Mode with `Annotated` `Strict`](../concepts/strict_mode.md#strict-mode-with-annotated-strict)
119
+
120
+ A field metadata class to indicate that a field should be validated in strict mode.
121
+ Use this class as an annotation via [`Annotated`](https://docs.python.org/3/library/typing.html#typing.Annotated), as seen below.
122
+
123
+ Attributes:
124
+ strict: Whether to validate the field in strict mode.
125
+
126
+ Example:
127
+ ```python
128
+ from typing import Annotated
129
+
130
+ from pydantic.types import Strict
131
+
132
+ StrictBool = Annotated[bool, Strict()]
133
+ ```
134
+ """
135
+
136
+ strict: bool = True
137
+
138
+ def __hash__(self) -> int:
139
+ return hash(self.strict)
140
+
141
+
142
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ BOOLEAN TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
143
+
144
+ StrictBool = Annotated[bool, Strict()]
145
+ """A boolean that must be either ``True`` or ``False``."""
146
+
147
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ INTEGER TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
148
+
149
+
150
+ def conint(
151
+ *,
152
+ strict: bool | None = None,
153
+ gt: int | None = None,
154
+ ge: int | None = None,
155
+ lt: int | None = None,
156
+ le: int | None = None,
157
+ multiple_of: int | None = None,
158
+ ) -> type[int]:
159
+ """
160
+ !!! warning "Discouraged"
161
+ This function is **discouraged** in favor of using
162
+ [`Annotated`](https://docs.python.org/3/library/typing.html#typing.Annotated) with
163
+ [`Field`][pydantic.fields.Field] instead.
164
+
165
+ This function will be **deprecated** in Pydantic 3.0.
166
+
167
+ The reason is that `conint` returns a type, which doesn't play well with static analysis tools.
168
+
169
+ === ":x: Don't do this"
170
+ ```python
171
+ from pydantic import BaseModel, conint
172
+
173
+ class Foo(BaseModel):
174
+ bar: conint(strict=True, gt=0)
175
+ ```
176
+
177
+ === ":white_check_mark: Do this"
178
+ ```python
179
+ from typing import Annotated
180
+
181
+ from pydantic import BaseModel, Field
182
+
183
+ class Foo(BaseModel):
184
+ bar: Annotated[int, Field(strict=True, gt=0)]
185
+ ```
186
+
187
+ A wrapper around `int` that allows for additional constraints.
188
+
189
+ Args:
190
+ strict: Whether to validate the integer in strict mode. Defaults to `None`.
191
+ gt: The value must be greater than this.
192
+ ge: The value must be greater than or equal to this.
193
+ lt: The value must be less than this.
194
+ le: The value must be less than or equal to this.
195
+ multiple_of: The value must be a multiple of this.
196
+
197
+ Returns:
198
+ The wrapped integer type.
199
+
200
+ ```python
201
+ from pydantic import BaseModel, ValidationError, conint
202
+
203
+ class ConstrainedExample(BaseModel):
204
+ constrained_int: conint(gt=1)
205
+
206
+ m = ConstrainedExample(constrained_int=2)
207
+ print(repr(m))
208
+ #> ConstrainedExample(constrained_int=2)
209
+
210
+ try:
211
+ ConstrainedExample(constrained_int=0)
212
+ except ValidationError as e:
213
+ print(e.errors())
214
+ '''
215
+ [
216
+ {
217
+ 'type': 'greater_than',
218
+ 'loc': ('constrained_int',),
219
+ 'msg': 'Input should be greater than 1',
220
+ 'input': 0,
221
+ 'ctx': {'gt': 1},
222
+ 'url': 'https://errors.pydantic.dev/2/v/greater_than',
223
+ }
224
+ ]
225
+ '''
226
+ ```
227
+
228
+ """ # noqa: D212
229
+ return Annotated[ # pyright: ignore[reportReturnType]
230
+ int,
231
+ Strict(strict) if strict is not None else None,
232
+ annotated_types.Interval(gt=gt, ge=ge, lt=lt, le=le),
233
+ annotated_types.MultipleOf(multiple_of) if multiple_of is not None else None,
234
+ ]
235
+
236
+
237
+ PositiveInt = Annotated[int, annotated_types.Gt(0)]
238
+ """An integer that must be greater than zero.
239
+
240
+ ```python
241
+ from pydantic import BaseModel, PositiveInt, ValidationError
242
+
243
+ class Model(BaseModel):
244
+ positive_int: PositiveInt
245
+
246
+ m = Model(positive_int=1)
247
+ print(repr(m))
248
+ #> Model(positive_int=1)
249
+
250
+ try:
251
+ Model(positive_int=-1)
252
+ except ValidationError as e:
253
+ print(e.errors())
254
+ '''
255
+ [
256
+ {
257
+ 'type': 'greater_than',
258
+ 'loc': ('positive_int',),
259
+ 'msg': 'Input should be greater than 0',
260
+ 'input': -1,
261
+ 'ctx': {'gt': 0},
262
+ 'url': 'https://errors.pydantic.dev/2/v/greater_than',
263
+ }
264
+ ]
265
+ '''
266
+ ```
267
+ """
268
+ NegativeInt = Annotated[int, annotated_types.Lt(0)]
269
+ """An integer that must be less than zero.
270
+
271
+ ```python
272
+ from pydantic import BaseModel, NegativeInt, ValidationError
273
+
274
+ class Model(BaseModel):
275
+ negative_int: NegativeInt
276
+
277
+ m = Model(negative_int=-1)
278
+ print(repr(m))
279
+ #> Model(negative_int=-1)
280
+
281
+ try:
282
+ Model(negative_int=1)
283
+ except ValidationError as e:
284
+ print(e.errors())
285
+ '''
286
+ [
287
+ {
288
+ 'type': 'less_than',
289
+ 'loc': ('negative_int',),
290
+ 'msg': 'Input should be less than 0',
291
+ 'input': 1,
292
+ 'ctx': {'lt': 0},
293
+ 'url': 'https://errors.pydantic.dev/2/v/less_than',
294
+ }
295
+ ]
296
+ '''
297
+ ```
298
+ """
299
+ NonPositiveInt = Annotated[int, annotated_types.Le(0)]
300
+ """An integer that must be less than or equal to zero.
301
+
302
+ ```python
303
+ from pydantic import BaseModel, NonPositiveInt, ValidationError
304
+
305
+ class Model(BaseModel):
306
+ non_positive_int: NonPositiveInt
307
+
308
+ m = Model(non_positive_int=0)
309
+ print(repr(m))
310
+ #> Model(non_positive_int=0)
311
+
312
+ try:
313
+ Model(non_positive_int=1)
314
+ except ValidationError as e:
315
+ print(e.errors())
316
+ '''
317
+ [
318
+ {
319
+ 'type': 'less_than_equal',
320
+ 'loc': ('non_positive_int',),
321
+ 'msg': 'Input should be less than or equal to 0',
322
+ 'input': 1,
323
+ 'ctx': {'le': 0},
324
+ 'url': 'https://errors.pydantic.dev/2/v/less_than_equal',
325
+ }
326
+ ]
327
+ '''
328
+ ```
329
+ """
330
+ NonNegativeInt = Annotated[int, annotated_types.Ge(0)]
331
+ """An integer that must be greater than or equal to zero.
332
+
333
+ ```python
334
+ from pydantic import BaseModel, NonNegativeInt, ValidationError
335
+
336
+ class Model(BaseModel):
337
+ non_negative_int: NonNegativeInt
338
+
339
+ m = Model(non_negative_int=0)
340
+ print(repr(m))
341
+ #> Model(non_negative_int=0)
342
+
343
+ try:
344
+ Model(non_negative_int=-1)
345
+ except ValidationError as e:
346
+ print(e.errors())
347
+ '''
348
+ [
349
+ {
350
+ 'type': 'greater_than_equal',
351
+ 'loc': ('non_negative_int',),
352
+ 'msg': 'Input should be greater than or equal to 0',
353
+ 'input': -1,
354
+ 'ctx': {'ge': 0},
355
+ 'url': 'https://errors.pydantic.dev/2/v/greater_than_equal',
356
+ }
357
+ ]
358
+ '''
359
+ ```
360
+ """
361
+ StrictInt = Annotated[int, Strict()]
362
+ """An integer that must be validated in strict mode.
363
+
364
+ ```python
365
+ from pydantic import BaseModel, StrictInt, ValidationError
366
+
367
+ class StrictIntModel(BaseModel):
368
+ strict_int: StrictInt
369
+
370
+ try:
371
+ StrictIntModel(strict_int=3.14159)
372
+ except ValidationError as e:
373
+ print(e)
374
+ '''
375
+ 1 validation error for StrictIntModel
376
+ strict_int
377
+ Input should be a valid integer [type=int_type, input_value=3.14159, input_type=float]
378
+ '''
379
+ ```
380
+ """
381
+
382
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ FLOAT TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
383
+
384
+
385
+ @_dataclasses.dataclass
386
+ class AllowInfNan(_fields.PydanticMetadata):
387
+ """A field metadata class to indicate that a field should allow `-inf`, `inf`, and `nan`.
388
+
389
+ Use this class as an annotation via [`Annotated`](https://docs.python.org/3/library/typing.html#typing.Annotated), as seen below.
390
+
391
+ Attributes:
392
+ allow_inf_nan: Whether to allow `-inf`, `inf`, and `nan`. Defaults to `True`.
393
+
394
+ Example:
395
+ ```python
396
+ from typing import Annotated
397
+
398
+ from pydantic.types import AllowInfNan
399
+
400
+ LaxFloat = Annotated[float, AllowInfNan()]
401
+ ```
402
+ """
403
+
404
+ allow_inf_nan: bool = True
405
+
406
+ def __hash__(self) -> int:
407
+ return hash(self.allow_inf_nan)
408
+
409
+
410
+ def confloat(
411
+ *,
412
+ strict: bool | None = None,
413
+ gt: float | None = None,
414
+ ge: float | None = None,
415
+ lt: float | None = None,
416
+ le: float | None = None,
417
+ multiple_of: float | None = None,
418
+ allow_inf_nan: bool | None = None,
419
+ ) -> type[float]:
420
+ """
421
+ !!! warning "Discouraged"
422
+ This function is **discouraged** in favor of using
423
+ [`Annotated`](https://docs.python.org/3/library/typing.html#typing.Annotated) with
424
+ [`Field`][pydantic.fields.Field] instead.
425
+
426
+ This function will be **deprecated** in Pydantic 3.0.
427
+
428
+ The reason is that `confloat` returns a type, which doesn't play well with static analysis tools.
429
+
430
+ === ":x: Don't do this"
431
+ ```python
432
+ from pydantic import BaseModel, confloat
433
+
434
+ class Foo(BaseModel):
435
+ bar: confloat(strict=True, gt=0)
436
+ ```
437
+
438
+ === ":white_check_mark: Do this"
439
+ ```python
440
+ from typing import Annotated
441
+
442
+ from pydantic import BaseModel, Field
443
+
444
+ class Foo(BaseModel):
445
+ bar: Annotated[float, Field(strict=True, gt=0)]
446
+ ```
447
+
448
+ A wrapper around `float` that allows for additional constraints.
449
+
450
+ Args:
451
+ strict: Whether to validate the float in strict mode.
452
+ gt: The value must be greater than this.
453
+ ge: The value must be greater than or equal to this.
454
+ lt: The value must be less than this.
455
+ le: The value must be less than or equal to this.
456
+ multiple_of: The value must be a multiple of this.
457
+ allow_inf_nan: Whether to allow `-inf`, `inf`, and `nan`.
458
+
459
+ Returns:
460
+ The wrapped float type.
461
+
462
+ ```python
463
+ from pydantic import BaseModel, ValidationError, confloat
464
+
465
+ class ConstrainedExample(BaseModel):
466
+ constrained_float: confloat(gt=1.0)
467
+
468
+ m = ConstrainedExample(constrained_float=1.1)
469
+ print(repr(m))
470
+ #> ConstrainedExample(constrained_float=1.1)
471
+
472
+ try:
473
+ ConstrainedExample(constrained_float=0.9)
474
+ except ValidationError as e:
475
+ print(e.errors())
476
+ '''
477
+ [
478
+ {
479
+ 'type': 'greater_than',
480
+ 'loc': ('constrained_float',),
481
+ 'msg': 'Input should be greater than 1',
482
+ 'input': 0.9,
483
+ 'ctx': {'gt': 1.0},
484
+ 'url': 'https://errors.pydantic.dev/2/v/greater_than',
485
+ }
486
+ ]
487
+ '''
488
+ ```
489
+ """ # noqa: D212
490
+ return Annotated[ # pyright: ignore[reportReturnType]
491
+ float,
492
+ Strict(strict) if strict is not None else None,
493
+ annotated_types.Interval(gt=gt, ge=ge, lt=lt, le=le),
494
+ annotated_types.MultipleOf(multiple_of) if multiple_of is not None else None,
495
+ AllowInfNan(allow_inf_nan) if allow_inf_nan is not None else None,
496
+ ]
497
+
498
+
499
+ PositiveFloat = Annotated[float, annotated_types.Gt(0)]
500
+ """A float that must be greater than zero.
501
+
502
+ ```python
503
+ from pydantic import BaseModel, PositiveFloat, ValidationError
504
+
505
+ class Model(BaseModel):
506
+ positive_float: PositiveFloat
507
+
508
+ m = Model(positive_float=1.0)
509
+ print(repr(m))
510
+ #> Model(positive_float=1.0)
511
+
512
+ try:
513
+ Model(positive_float=-1.0)
514
+ except ValidationError as e:
515
+ print(e.errors())
516
+ '''
517
+ [
518
+ {
519
+ 'type': 'greater_than',
520
+ 'loc': ('positive_float',),
521
+ 'msg': 'Input should be greater than 0',
522
+ 'input': -1.0,
523
+ 'ctx': {'gt': 0.0},
524
+ 'url': 'https://errors.pydantic.dev/2/v/greater_than',
525
+ }
526
+ ]
527
+ '''
528
+ ```
529
+ """
530
+ NegativeFloat = Annotated[float, annotated_types.Lt(0)]
531
+ """A float that must be less than zero.
532
+
533
+ ```python
534
+ from pydantic import BaseModel, NegativeFloat, ValidationError
535
+
536
+ class Model(BaseModel):
537
+ negative_float: NegativeFloat
538
+
539
+ m = Model(negative_float=-1.0)
540
+ print(repr(m))
541
+ #> Model(negative_float=-1.0)
542
+
543
+ try:
544
+ Model(negative_float=1.0)
545
+ except ValidationError as e:
546
+ print(e.errors())
547
+ '''
548
+ [
549
+ {
550
+ 'type': 'less_than',
551
+ 'loc': ('negative_float',),
552
+ 'msg': 'Input should be less than 0',
553
+ 'input': 1.0,
554
+ 'ctx': {'lt': 0.0},
555
+ 'url': 'https://errors.pydantic.dev/2/v/less_than',
556
+ }
557
+ ]
558
+ '''
559
+ ```
560
+ """
561
+ NonPositiveFloat = Annotated[float, annotated_types.Le(0)]
562
+ """A float that must be less than or equal to zero.
563
+
564
+ ```python
565
+ from pydantic import BaseModel, NonPositiveFloat, ValidationError
566
+
567
+ class Model(BaseModel):
568
+ non_positive_float: NonPositiveFloat
569
+
570
+ m = Model(non_positive_float=0.0)
571
+ print(repr(m))
572
+ #> Model(non_positive_float=0.0)
573
+
574
+ try:
575
+ Model(non_positive_float=1.0)
576
+ except ValidationError as e:
577
+ print(e.errors())
578
+ '''
579
+ [
580
+ {
581
+ 'type': 'less_than_equal',
582
+ 'loc': ('non_positive_float',),
583
+ 'msg': 'Input should be less than or equal to 0',
584
+ 'input': 1.0,
585
+ 'ctx': {'le': 0.0},
586
+ 'url': 'https://errors.pydantic.dev/2/v/less_than_equal',
587
+ }
588
+ ]
589
+ '''
590
+ ```
591
+ """
592
+ NonNegativeFloat = Annotated[float, annotated_types.Ge(0)]
593
+ """A float that must be greater than or equal to zero.
594
+
595
+ ```python
596
+ from pydantic import BaseModel, NonNegativeFloat, ValidationError
597
+
598
+ class Model(BaseModel):
599
+ non_negative_float: NonNegativeFloat
600
+
601
+ m = Model(non_negative_float=0.0)
602
+ print(repr(m))
603
+ #> Model(non_negative_float=0.0)
604
+
605
+ try:
606
+ Model(non_negative_float=-1.0)
607
+ except ValidationError as e:
608
+ print(e.errors())
609
+ '''
610
+ [
611
+ {
612
+ 'type': 'greater_than_equal',
613
+ 'loc': ('non_negative_float',),
614
+ 'msg': 'Input should be greater than or equal to 0',
615
+ 'input': -1.0,
616
+ 'ctx': {'ge': 0.0},
617
+ 'url': 'https://errors.pydantic.dev/2/v/greater_than_equal',
618
+ }
619
+ ]
620
+ '''
621
+ ```
622
+ """
623
+ StrictFloat = Annotated[float, Strict(True)]
624
+ """A float that must be validated in strict mode.
625
+
626
+ ```python
627
+ from pydantic import BaseModel, StrictFloat, ValidationError
628
+
629
+ class StrictFloatModel(BaseModel):
630
+ strict_float: StrictFloat
631
+
632
+ try:
633
+ StrictFloatModel(strict_float='1.0')
634
+ except ValidationError as e:
635
+ print(e)
636
+ '''
637
+ 1 validation error for StrictFloatModel
638
+ strict_float
639
+ Input should be a valid number [type=float_type, input_value='1.0', input_type=str]
640
+ '''
641
+ ```
642
+ """
643
+ FiniteFloat = Annotated[float, AllowInfNan(False)]
644
+ """A float that must be finite (not ``-inf``, ``inf``, or ``nan``).
645
+
646
+ ```python
647
+ from pydantic import BaseModel, FiniteFloat
648
+
649
+ class Model(BaseModel):
650
+ finite: FiniteFloat
651
+
652
+ m = Model(finite=1.0)
653
+ print(m)
654
+ #> finite=1.0
655
+ ```
656
+ """
657
+
658
+
659
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ BYTES TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
660
+
661
+
662
+ def conbytes(
663
+ *,
664
+ min_length: int | None = None,
665
+ max_length: int | None = None,
666
+ strict: bool | None = None,
667
+ ) -> type[bytes]:
668
+ """A wrapper around `bytes` that allows for additional constraints.
669
+
670
+ Args:
671
+ min_length: The minimum length of the bytes.
672
+ max_length: The maximum length of the bytes.
673
+ strict: Whether to validate the bytes in strict mode.
674
+
675
+ Returns:
676
+ The wrapped bytes type.
677
+ """
678
+ return Annotated[ # pyright: ignore[reportReturnType]
679
+ bytes,
680
+ Strict(strict) if strict is not None else None,
681
+ annotated_types.Len(min_length or 0, max_length),
682
+ ]
683
+
684
+
685
+ StrictBytes = Annotated[bytes, Strict()]
686
+ """A bytes that must be validated in strict mode."""
687
+
688
+
689
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ STRING TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
690
+
691
+
692
+ @_dataclasses.dataclass(frozen=True)
693
+ class StringConstraints(annotated_types.GroupedMetadata):
694
+ """!!! abstract "Usage Documentation"
695
+ [String types](./standard_library_types.md#strings)
696
+
697
+ A field metadata class to apply constraints to `str` types.
698
+ Use this class as an annotation via [`Annotated`](https://docs.python.org/3/library/typing.html#typing.Annotated), as seen below.
699
+
700
+ Attributes:
701
+ strip_whitespace: Whether to remove leading and trailing whitespace.
702
+ to_upper: Whether to convert the string to uppercase.
703
+ to_lower: Whether to convert the string to lowercase.
704
+ strict: Whether to validate the string in strict mode.
705
+ min_length: The minimum length of the string.
706
+ max_length: The maximum length of the string.
707
+ pattern: A regex pattern that the string must match.
708
+ ascii_only: Whether the string should contain only ASCII characters.
709
+
710
+ Example:
711
+ ```python
712
+ from typing import Annotated
713
+
714
+ from pydantic.types import StringConstraints
715
+
716
+ ConstrainedStr = Annotated[str, StringConstraints(min_length=1, max_length=10)]
717
+ ```
718
+ """
719
+
720
+ strip_whitespace: bool | None = None
721
+ to_upper: bool | None = None
722
+ to_lower: bool | None = None
723
+ strict: bool | None = None
724
+ min_length: int | None = None
725
+ max_length: int | None = None
726
+ pattern: str | Pattern[str] | None = None
727
+ ascii_only: bool | None = None
728
+
729
+ def __iter__(self) -> Iterator[BaseMetadata]:
730
+ if self.min_length is not None:
731
+ yield MinLen(self.min_length)
732
+ if self.max_length is not None:
733
+ yield MaxLen(self.max_length)
734
+ if self.strict is not None:
735
+ yield Strict(self.strict)
736
+ if (
737
+ self.strip_whitespace is not None
738
+ or self.pattern is not None
739
+ or self.to_lower is not None
740
+ or self.to_upper is not None
741
+ or self.ascii_only is not None
742
+ ):
743
+ yield _fields.pydantic_general_metadata(
744
+ strip_whitespace=self.strip_whitespace,
745
+ to_upper=self.to_upper,
746
+ to_lower=self.to_lower,
747
+ pattern=self.pattern,
748
+ ascii_only=self.ascii_only,
749
+ )
750
+
751
+
752
+ def constr(
753
+ *,
754
+ strip_whitespace: bool | None = None,
755
+ to_upper: bool | None = None,
756
+ to_lower: bool | None = None,
757
+ strict: bool | None = None,
758
+ min_length: int | None = None,
759
+ max_length: int | None = None,
760
+ pattern: str | Pattern[str] | None = None,
761
+ ascii_only: bool | None = None,
762
+ ) -> type[str]:
763
+ """
764
+ !!! warning "Discouraged"
765
+ This function is **discouraged** in favor of using
766
+ [`Annotated`](https://docs.python.org/3/library/typing.html#typing.Annotated) with
767
+ [`StringConstraints`][pydantic.types.StringConstraints] instead.
768
+
769
+ This function will be **deprecated** in Pydantic 3.0.
770
+
771
+ The reason is that `constr` returns a type, which doesn't play well with static analysis tools.
772
+
773
+ === ":x: Don't do this"
774
+ ```python
775
+ from pydantic import BaseModel, constr
776
+
777
+ class Foo(BaseModel):
778
+ bar: constr(strip_whitespace=True, to_upper=True, pattern=r'^[A-Z]+$')
779
+ ```
780
+
781
+ === ":white_check_mark: Do this"
782
+ ```python
783
+ from typing import Annotated
784
+
785
+ from pydantic import BaseModel, StringConstraints
786
+
787
+ class Foo(BaseModel):
788
+ bar: Annotated[
789
+ str,
790
+ StringConstraints(
791
+ strip_whitespace=True, to_upper=True, pattern=r'^[A-Z]+$'
792
+ ),
793
+ ]
794
+ ```
795
+
796
+ A wrapper around `str` that allows for additional constraints.
797
+
798
+ ```python
799
+ from pydantic import BaseModel, constr
800
+
801
+ class Foo(BaseModel):
802
+ bar: constr(strip_whitespace=True, to_upper=True)
803
+
804
+ foo = Foo(bar=' hello ')
805
+ print(foo)
806
+ #> bar='HELLO'
807
+ ```
808
+
809
+ Args:
810
+ strip_whitespace: Whether to remove leading and trailing whitespace.
811
+ to_upper: Whether to turn all characters to uppercase.
812
+ to_lower: Whether to turn all characters to lowercase.
813
+ strict: Whether to validate the string in strict mode.
814
+ min_length: The minimum length of the string.
815
+ max_length: The maximum length of the string.
816
+ pattern: A regex pattern to validate the string against.
817
+ ascii_only: Whether the string should contain only ASCII characters.
818
+
819
+ Returns:
820
+ The wrapped string type.
821
+ """ # noqa: D212
822
+ return Annotated[ # pyright: ignore[reportReturnType]
823
+ str,
824
+ StringConstraints(
825
+ strip_whitespace=strip_whitespace,
826
+ to_upper=to_upper,
827
+ to_lower=to_lower,
828
+ strict=strict,
829
+ min_length=min_length,
830
+ max_length=max_length,
831
+ pattern=pattern,
832
+ ascii_only=ascii_only,
833
+ ),
834
+ ]
835
+
836
+
837
+ StrictStr = Annotated[str, Strict()]
838
+ """A string that must be validated in strict mode."""
839
+
840
+
841
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~ COLLECTION TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
842
+ HashableItemType = TypeVar('HashableItemType', bound=Hashable)
843
+
844
+
845
+ def conset(
846
+ item_type: type[HashableItemType], *, min_length: int | None = None, max_length: int | None = None
847
+ ) -> type[set[HashableItemType]]:
848
+ """A wrapper around `typing.Set` that allows for additional constraints.
849
+
850
+ Args:
851
+ item_type: The type of the items in the set.
852
+ min_length: The minimum length of the set.
853
+ max_length: The maximum length of the set.
854
+
855
+ Returns:
856
+ The wrapped set type.
857
+ """
858
+ return Annotated[set[item_type], annotated_types.Len(min_length or 0, max_length)] # pyright: ignore[reportReturnType]
859
+
860
+
861
+ def confrozenset(
862
+ item_type: type[HashableItemType], *, min_length: int | None = None, max_length: int | None = None
863
+ ) -> type[frozenset[HashableItemType]]:
864
+ """A wrapper around `typing.FrozenSet` that allows for additional constraints.
865
+
866
+ Args:
867
+ item_type: The type of the items in the frozenset.
868
+ min_length: The minimum length of the frozenset.
869
+ max_length: The maximum length of the frozenset.
870
+
871
+ Returns:
872
+ The wrapped frozenset type.
873
+ """
874
+ return Annotated[frozenset[item_type], annotated_types.Len(min_length or 0, max_length)] # pyright: ignore[reportReturnType]
875
+
876
+
877
+ AnyItemType = TypeVar('AnyItemType')
878
+
879
+
880
+ def conlist(
881
+ item_type: type[AnyItemType],
882
+ *,
883
+ min_length: int | None = None,
884
+ max_length: int | None = None,
885
+ unique_items: bool | None = None,
886
+ ) -> type[list[AnyItemType]]:
887
+ """A wrapper around [`list`][] that adds validation.
888
+
889
+ Args:
890
+ item_type: The type of the items in the list.
891
+ min_length: The minimum length of the list. Defaults to None.
892
+ max_length: The maximum length of the list. Defaults to None.
893
+ unique_items: Whether the items in the list must be unique. Defaults to None.
894
+ !!! warning Deprecated
895
+ The `unique_items` parameter is deprecated, use `Set` instead.
896
+ See [this issue](https://github.com/pydantic/pydantic-core/issues/296) for more details.
897
+
898
+ Returns:
899
+ The wrapped list type.
900
+ """
901
+ if unique_items is not None:
902
+ raise PydanticUserError(
903
+ (
904
+ '`unique_items` is removed, use `Set` instead'
905
+ '(this feature is discussed in https://github.com/pydantic/pydantic-core/issues/296)'
906
+ ),
907
+ code='removed-kwargs',
908
+ )
909
+ return Annotated[list[item_type], annotated_types.Len(min_length or 0, max_length)] # pyright: ignore[reportReturnType]
910
+
911
+
912
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~ IMPORT STRING TYPE ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
913
+
914
+ AnyType = TypeVar('AnyType')
915
+ if TYPE_CHECKING:
916
+ ImportString = Annotated[AnyType, ...]
917
+ else:
918
+
919
+ class ImportString:
920
+ """A type that can be used to import a Python object from a string.
921
+
922
+ `ImportString` expects a string and loads the Python object importable at that dotted path.
923
+ Attributes of modules may be separated from the module by `:` or `.`, e.g. if `'math:cos'` is provided,
924
+ the resulting field value would be the function `cos`. If a `.` is used and both an attribute and submodule
925
+ are present at the same path, the module will be preferred.
926
+
927
+ On model instantiation, pointers will be evaluated and imported. There is
928
+ some nuance to this behavior, demonstrated in the examples below.
929
+
930
+ ```python
931
+ import math
932
+
933
+ from pydantic import BaseModel, Field, ImportString, ValidationError
934
+
935
+ class ImportThings(BaseModel):
936
+ obj: ImportString
937
+
938
+ # A string value will cause an automatic import
939
+ my_cos = ImportThings(obj='math.cos')
940
+
941
+ # You can use the imported function as you would expect
942
+ cos_of_0 = my_cos.obj(0)
943
+ assert cos_of_0 == 1
944
+
945
+ # A string whose value cannot be imported will raise an error
946
+ try:
947
+ ImportThings(obj='foo.bar')
948
+ except ValidationError as e:
949
+ print(e)
950
+ '''
951
+ 1 validation error for ImportThings
952
+ obj
953
+ Invalid python path: No module named 'foo' [type=import_error, input_value='foo.bar', input_type=str]
954
+ '''
955
+
956
+ # Actual python objects can be assigned as well
957
+ my_cos = ImportThings(obj=math.cos)
958
+ my_cos_2 = ImportThings(obj='math.cos')
959
+ my_cos_3 = ImportThings(obj='math:cos')
960
+ assert my_cos == my_cos_2 == my_cos_3
961
+
962
+ # You can set default field value either as Python object:
963
+ class ImportThingsDefaultPyObj(BaseModel):
964
+ obj: ImportString = math.cos
965
+
966
+ # or as a string value (but only if used with `validate_default=True`)
967
+ class ImportThingsDefaultString(BaseModel):
968
+ obj: ImportString = Field(default='math.cos', validate_default=True)
969
+
970
+ my_cos_default1 = ImportThingsDefaultPyObj()
971
+ my_cos_default2 = ImportThingsDefaultString()
972
+ assert my_cos_default1.obj == my_cos_default2.obj == math.cos
973
+
974
+ # note: this will not work!
975
+ class ImportThingsMissingValidateDefault(BaseModel):
976
+ obj: ImportString = 'math.cos'
977
+
978
+ my_cos_default3 = ImportThingsMissingValidateDefault()
979
+ assert my_cos_default3.obj == 'math.cos' # just string, not evaluated
980
+ ```
981
+
982
+ Serializing an `ImportString` type to json is also possible.
983
+
984
+ ```python
985
+ from pydantic import BaseModel, ImportString
986
+
987
+ class ImportThings(BaseModel):
988
+ obj: ImportString
989
+
990
+ # Create an instance
991
+ m = ImportThings(obj='math.cos')
992
+ print(m)
993
+ #> obj=<built-in function cos>
994
+ print(m.model_dump_json())
995
+ #> {"obj":"math.cos"}
996
+ ```
997
+ """
998
+
999
+ @classmethod
1000
+ def __class_getitem__(cls, item: AnyType) -> AnyType:
1001
+ return Annotated[item, cls()]
1002
+
1003
+ @classmethod
1004
+ def __get_pydantic_core_schema__(
1005
+ cls, source: type[Any], handler: GetCoreSchemaHandler
1006
+ ) -> core_schema.CoreSchema:
1007
+ serializer = core_schema.plain_serializer_function_ser_schema(cls._serialize, when_used='json')
1008
+ if cls is source:
1009
+ # Treat bare usage of ImportString (`schema is None`) as the same as ImportString[Any]
1010
+ return core_schema.no_info_plain_validator_function(
1011
+ function=_validators.import_string, serialization=serializer
1012
+ )
1013
+ else:
1014
+ return core_schema.no_info_before_validator_function(
1015
+ function=_validators.import_string, schema=handler(source), serialization=serializer
1016
+ )
1017
+
1018
+ @classmethod
1019
+ def __get_pydantic_json_schema__(cls, cs: CoreSchema, handler: GetJsonSchemaHandler) -> JsonSchemaValue:
1020
+ return handler(core_schema.str_schema())
1021
+
1022
+ @staticmethod
1023
+ def _serialize(v: Any) -> str:
1024
+ if isinstance(v, ModuleType):
1025
+ return v.__name__
1026
+ elif hasattr(v, '__module__') and hasattr(v, '__name__'):
1027
+ return f'{v.__module__}.{v.__name__}'
1028
+ # Handle special cases for sys.XXX streams
1029
+ # if we see more of these, we should consider a more general solution
1030
+ elif hasattr(v, 'name'):
1031
+ if v.name == '<stdout>':
1032
+ return 'sys.stdout'
1033
+ elif v.name == '<stdin>':
1034
+ return 'sys.stdin'
1035
+ elif v.name == '<stderr>':
1036
+ return 'sys.stderr'
1037
+ return v
1038
+
1039
+ def __repr__(self) -> str:
1040
+ return 'ImportString'
1041
+
1042
+
1043
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ DECIMAL TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1044
+
1045
+
1046
+ def condecimal(
1047
+ *,
1048
+ strict: bool | None = None,
1049
+ gt: int | Decimal | None = None,
1050
+ ge: int | Decimal | None = None,
1051
+ lt: int | Decimal | None = None,
1052
+ le: int | Decimal | None = None,
1053
+ multiple_of: int | Decimal | None = None,
1054
+ max_digits: int | None = None,
1055
+ decimal_places: int | None = None,
1056
+ allow_inf_nan: bool | None = None,
1057
+ ) -> type[Decimal]:
1058
+ """
1059
+ !!! warning "Discouraged"
1060
+ This function is **discouraged** in favor of using
1061
+ [`Annotated`](https://docs.python.org/3/library/typing.html#typing.Annotated) with
1062
+ [`Field`][pydantic.fields.Field] instead.
1063
+
1064
+ This function will be **deprecated** in Pydantic 3.0.
1065
+
1066
+ The reason is that `condecimal` returns a type, which doesn't play well with static analysis tools.
1067
+
1068
+ === ":x: Don't do this"
1069
+ ```python
1070
+ from pydantic import BaseModel, condecimal
1071
+
1072
+ class Foo(BaseModel):
1073
+ bar: condecimal(strict=True, allow_inf_nan=True)
1074
+ ```
1075
+
1076
+ === ":white_check_mark: Do this"
1077
+ ```python
1078
+ from decimal import Decimal
1079
+ from typing import Annotated
1080
+
1081
+ from pydantic import BaseModel, Field
1082
+
1083
+ class Foo(BaseModel):
1084
+ bar: Annotated[Decimal, Field(strict=True, allow_inf_nan=True)]
1085
+ ```
1086
+
1087
+ A wrapper around Decimal that adds validation.
1088
+
1089
+ Args:
1090
+ strict: Whether to validate the value in strict mode. Defaults to `None`.
1091
+ gt: The value must be greater than this. Defaults to `None`.
1092
+ ge: The value must be greater than or equal to this. Defaults to `None`.
1093
+ lt: The value must be less than this. Defaults to `None`.
1094
+ le: The value must be less than or equal to this. Defaults to `None`.
1095
+ multiple_of: The value must be a multiple of this. Defaults to `None`.
1096
+ max_digits: The maximum number of digits. Defaults to `None`.
1097
+ decimal_places: The number of decimal places. Defaults to `None`.
1098
+ allow_inf_nan: Whether to allow infinity and NaN. Defaults to `None`.
1099
+
1100
+ ```python
1101
+ from decimal import Decimal
1102
+
1103
+ from pydantic import BaseModel, ValidationError, condecimal
1104
+
1105
+ class ConstrainedExample(BaseModel):
1106
+ constrained_decimal: condecimal(gt=Decimal('1.0'))
1107
+
1108
+ m = ConstrainedExample(constrained_decimal=Decimal('1.1'))
1109
+ print(repr(m))
1110
+ #> ConstrainedExample(constrained_decimal=Decimal('1.1'))
1111
+
1112
+ try:
1113
+ ConstrainedExample(constrained_decimal=Decimal('0.9'))
1114
+ except ValidationError as e:
1115
+ print(e.errors())
1116
+ '''
1117
+ [
1118
+ {
1119
+ 'type': 'greater_than',
1120
+ 'loc': ('constrained_decimal',),
1121
+ 'msg': 'Input should be greater than 1.0',
1122
+ 'input': Decimal('0.9'),
1123
+ 'ctx': {'gt': Decimal('1.0')},
1124
+ 'url': 'https://errors.pydantic.dev/2/v/greater_than',
1125
+ }
1126
+ ]
1127
+ '''
1128
+ ```
1129
+ """ # noqa: D212
1130
+ return Annotated[ # pyright: ignore[reportReturnType]
1131
+ Decimal,
1132
+ Strict(strict) if strict is not None else None,
1133
+ annotated_types.Interval(gt=gt, ge=ge, lt=lt, le=le),
1134
+ annotated_types.MultipleOf(multiple_of) if multiple_of is not None else None,
1135
+ _fields.pydantic_general_metadata(max_digits=max_digits, decimal_places=decimal_places),
1136
+ AllowInfNan(allow_inf_nan) if allow_inf_nan is not None else None,
1137
+ ]
1138
+
1139
+
1140
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ UUID TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1141
+
1142
+
1143
+ @_dataclasses.dataclass(**_internal_dataclass.slots_true)
1144
+ class UuidVersion:
1145
+ """A field metadata class to indicate a [UUID](https://docs.python.org/3/library/uuid.html) version.
1146
+
1147
+ Use this class as an annotation via [`Annotated`](https://docs.python.org/3/library/typing.html#typing.Annotated), as seen below.
1148
+
1149
+ Attributes:
1150
+ uuid_version: The version of the UUID. Must be one of 1, 3, 4, 5, 6, 7 or 8.
1151
+
1152
+ Example:
1153
+ ```python
1154
+ from typing import Annotated
1155
+ from uuid import UUID
1156
+
1157
+ from pydantic.types import UuidVersion
1158
+
1159
+ UUID1 = Annotated[UUID, UuidVersion(1)]
1160
+ ```
1161
+ """
1162
+
1163
+ uuid_version: Literal[1, 3, 4, 5, 6, 7, 8]
1164
+
1165
+ def __get_pydantic_json_schema__(
1166
+ self, core_schema: core_schema.CoreSchema, handler: GetJsonSchemaHandler
1167
+ ) -> JsonSchemaValue:
1168
+ field_schema = handler(core_schema)
1169
+ field_schema.pop('anyOf', None) # remove the bytes/str union
1170
+ field_schema.update(type='string', format=f'uuid{self.uuid_version}')
1171
+ return field_schema
1172
+
1173
+ def __get_pydantic_core_schema__(self, source: Any, handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
1174
+ schema = handler(source)
1175
+ _check_annotated_type(schema['type'], 'uuid', self.__class__.__name__)
1176
+ schema['version'] = self.uuid_version # type: ignore
1177
+ return schema
1178
+
1179
+ def __hash__(self) -> int:
1180
+ return hash(self.uuid_version)
1181
+
1182
+
1183
+ UUID1 = Annotated[UUID, UuidVersion(1)]
1184
+ """A [UUID](https://docs.python.org/3/library/uuid.html) that must be version 1.
1185
+
1186
+ ```python
1187
+ import uuid
1188
+
1189
+ from pydantic import UUID1, BaseModel
1190
+
1191
+ class Model(BaseModel):
1192
+ uuid1: UUID1
1193
+
1194
+ Model(uuid1=uuid.uuid1())
1195
+ ```
1196
+ """
1197
+ UUID3 = Annotated[UUID, UuidVersion(3)]
1198
+ """A [UUID](https://docs.python.org/3/library/uuid.html) that must be version 3.
1199
+
1200
+ ```python
1201
+ import uuid
1202
+
1203
+ from pydantic import UUID3, BaseModel
1204
+
1205
+ class Model(BaseModel):
1206
+ uuid3: UUID3
1207
+
1208
+ Model(uuid3=uuid.uuid3(uuid.NAMESPACE_DNS, 'pydantic.org'))
1209
+ ```
1210
+ """
1211
+ UUID4 = Annotated[UUID, UuidVersion(4)]
1212
+ """A [UUID](https://docs.python.org/3/library/uuid.html) that must be version 4.
1213
+
1214
+ ```python
1215
+ import uuid
1216
+
1217
+ from pydantic import UUID4, BaseModel
1218
+
1219
+ class Model(BaseModel):
1220
+ uuid4: UUID4
1221
+
1222
+ Model(uuid4=uuid.uuid4())
1223
+ ```
1224
+ """
1225
+ UUID5 = Annotated[UUID, UuidVersion(5)]
1226
+ """A [UUID](https://docs.python.org/3/library/uuid.html) that must be version 5.
1227
+
1228
+ ```python
1229
+ import uuid
1230
+
1231
+ from pydantic import UUID5, BaseModel
1232
+
1233
+ class Model(BaseModel):
1234
+ uuid5: UUID5
1235
+
1236
+ Model(uuid5=uuid.uuid5(uuid.NAMESPACE_DNS, 'pydantic.org'))
1237
+ ```
1238
+ """
1239
+ UUID6 = Annotated[UUID, UuidVersion(6)]
1240
+ """A [UUID](https://docs.python.org/3/library/uuid.html) that must be version 6.
1241
+
1242
+ ```python
1243
+ import uuid
1244
+
1245
+ from pydantic import UUID6, BaseModel
1246
+
1247
+ class Model(BaseModel):
1248
+ uuid6: UUID6
1249
+
1250
+ Model(uuid6=uuid.UUID('1efea953-c2d6-6790-aa0a-69db8c87df97'))
1251
+ ```
1252
+ """
1253
+ UUID7 = Annotated[UUID, UuidVersion(7)]
1254
+ """A [UUID](https://docs.python.org/3/library/uuid.html) that must be version 7.
1255
+
1256
+ ```python
1257
+ import uuid
1258
+
1259
+ from pydantic import UUID7, BaseModel
1260
+
1261
+ class Model(BaseModel):
1262
+ uuid7: UUID7
1263
+
1264
+ Model(uuid7=uuid.UUID('0194fdcb-1c47-7a09-b52c-561154de0b4a'))
1265
+ ```
1266
+ """
1267
+ UUID8 = Annotated[UUID, UuidVersion(8)]
1268
+ """A [UUID](https://docs.python.org/3/library/uuid.html) that must be version 8.
1269
+
1270
+ ```python
1271
+ import uuid
1272
+
1273
+ from pydantic import UUID8, BaseModel
1274
+
1275
+ class Model(BaseModel):
1276
+ uuid8: UUID8
1277
+
1278
+ Model(uuid8=uuid.UUID('81a0b92e-6078-8551-9c81-8ccb666bdab8'))
1279
+ ```
1280
+ """
1281
+
1282
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ PATH TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1283
+
1284
+
1285
+ @_dataclasses.dataclass
1286
+ class PathType:
1287
+ path_type: Literal['file', 'dir', 'new', 'socket']
1288
+
1289
+ def __get_pydantic_json_schema__(
1290
+ self, core_schema: core_schema.CoreSchema, handler: GetJsonSchemaHandler
1291
+ ) -> JsonSchemaValue:
1292
+ field_schema = handler(core_schema)
1293
+ format_conversion = {'file': 'file-path', 'dir': 'directory-path'}
1294
+ field_schema.update(format=format_conversion.get(self.path_type, 'path'), type='string')
1295
+ return field_schema
1296
+
1297
+ def __get_pydantic_core_schema__(self, source: Any, handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
1298
+ function_lookup = {
1299
+ 'file': cast(core_schema.WithInfoValidatorFunction, self.validate_file),
1300
+ 'dir': cast(core_schema.WithInfoValidatorFunction, self.validate_directory),
1301
+ 'new': cast(core_schema.WithInfoValidatorFunction, self.validate_new),
1302
+ 'socket': cast(core_schema.WithInfoValidatorFunction, self.validate_socket),
1303
+ }
1304
+
1305
+ return core_schema.with_info_after_validator_function(
1306
+ function_lookup[self.path_type],
1307
+ handler(source),
1308
+ )
1309
+
1310
+ @staticmethod
1311
+ def validate_file(path: Path, _: core_schema.ValidationInfo) -> Path:
1312
+ if path.is_file():
1313
+ return path
1314
+ else:
1315
+ raise PydanticCustomError('path_not_file', 'Path does not point to a file')
1316
+
1317
+ @staticmethod
1318
+ def validate_socket(path: Path, _: core_schema.ValidationInfo) -> Path:
1319
+ if path.is_socket():
1320
+ return path
1321
+ else:
1322
+ raise PydanticCustomError('path_not_socket', 'Path does not point to a socket')
1323
+
1324
+ @staticmethod
1325
+ def validate_directory(path: Path, _: core_schema.ValidationInfo) -> Path:
1326
+ if path.is_dir():
1327
+ return path
1328
+ else:
1329
+ raise PydanticCustomError('path_not_directory', 'Path does not point to a directory')
1330
+
1331
+ @staticmethod
1332
+ def validate_new(path: Path, _: core_schema.ValidationInfo) -> Path:
1333
+ if path.exists():
1334
+ raise PydanticCustomError('path_exists', 'Path already exists')
1335
+ elif not path.parent.exists():
1336
+ raise PydanticCustomError('parent_does_not_exist', 'Parent directory does not exist')
1337
+ else:
1338
+ return path
1339
+
1340
+ def __hash__(self) -> int:
1341
+ return hash(self.path_type)
1342
+
1343
+
1344
+ FilePath = Annotated[Path, PathType('file')]
1345
+ """A path that must point to a file.
1346
+
1347
+ ```python
1348
+ from pathlib import Path
1349
+
1350
+ from pydantic import BaseModel, FilePath, ValidationError
1351
+
1352
+ class Model(BaseModel):
1353
+ f: FilePath
1354
+
1355
+ path = Path('text.txt')
1356
+ path.touch()
1357
+ m = Model(f='text.txt')
1358
+ print(m.model_dump())
1359
+ #> {'f': PosixPath('text.txt')}
1360
+ path.unlink()
1361
+
1362
+ path = Path('directory')
1363
+ path.mkdir(exist_ok=True)
1364
+ try:
1365
+ Model(f='directory') # directory
1366
+ except ValidationError as e:
1367
+ print(e)
1368
+ '''
1369
+ 1 validation error for Model
1370
+ f
1371
+ Path does not point to a file [type=path_not_file, input_value='directory', input_type=str]
1372
+ '''
1373
+ path.rmdir()
1374
+
1375
+ try:
1376
+ Model(f='not-exists-file')
1377
+ except ValidationError as e:
1378
+ print(e)
1379
+ '''
1380
+ 1 validation error for Model
1381
+ f
1382
+ Path does not point to a file [type=path_not_file, input_value='not-exists-file', input_type=str]
1383
+ '''
1384
+ ```
1385
+ """
1386
+ DirectoryPath = Annotated[Path, PathType('dir')]
1387
+ """A path that must point to a directory.
1388
+
1389
+ ```python
1390
+ from pathlib import Path
1391
+
1392
+ from pydantic import BaseModel, DirectoryPath, ValidationError
1393
+
1394
+ class Model(BaseModel):
1395
+ f: DirectoryPath
1396
+
1397
+ path = Path('directory/')
1398
+ path.mkdir()
1399
+ m = Model(f='directory/')
1400
+ print(m.model_dump())
1401
+ #> {'f': PosixPath('directory')}
1402
+ path.rmdir()
1403
+
1404
+ path = Path('file.txt')
1405
+ path.touch()
1406
+ try:
1407
+ Model(f='file.txt') # file
1408
+ except ValidationError as e:
1409
+ print(e)
1410
+ '''
1411
+ 1 validation error for Model
1412
+ f
1413
+ Path does not point to a directory [type=path_not_directory, input_value='file.txt', input_type=str]
1414
+ '''
1415
+ path.unlink()
1416
+
1417
+ try:
1418
+ Model(f='not-exists-directory')
1419
+ except ValidationError as e:
1420
+ print(e)
1421
+ '''
1422
+ 1 validation error for Model
1423
+ f
1424
+ Path does not point to a directory [type=path_not_directory, input_value='not-exists-directory', input_type=str]
1425
+ '''
1426
+ ```
1427
+ """
1428
+ NewPath = Annotated[Path, PathType('new')]
1429
+ """A path for a new file or directory that must not already exist. The parent directory must already exist."""
1430
+
1431
+ SocketPath = Annotated[Path, PathType('socket')]
1432
+ """A path to an existing socket file"""
1433
+
1434
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ JSON TYPE ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1435
+
1436
+ if TYPE_CHECKING:
1437
+ # Json[list[str]] will be recognized by type checkers as list[str]
1438
+ Json = Annotated[AnyType, ...]
1439
+
1440
+ else:
1441
+
1442
+ class Json:
1443
+ """A special type wrapper which loads JSON before parsing.
1444
+
1445
+ You can use the `Json` data type to make Pydantic first load a raw JSON string before
1446
+ validating the loaded data into the parametrized type:
1447
+
1448
+ ```python
1449
+ from typing import Any
1450
+
1451
+ from pydantic import BaseModel, Json, ValidationError
1452
+
1453
+ class AnyJsonModel(BaseModel):
1454
+ json_obj: Json[Any]
1455
+
1456
+ class ConstrainedJsonModel(BaseModel):
1457
+ json_obj: Json[list[int]]
1458
+
1459
+ print(AnyJsonModel(json_obj='{"b": 1}'))
1460
+ #> json_obj={'b': 1}
1461
+ print(ConstrainedJsonModel(json_obj='[1, 2, 3]'))
1462
+ #> json_obj=[1, 2, 3]
1463
+
1464
+ try:
1465
+ ConstrainedJsonModel(json_obj=12)
1466
+ except ValidationError as e:
1467
+ print(e)
1468
+ '''
1469
+ 1 validation error for ConstrainedJsonModel
1470
+ json_obj
1471
+ JSON input should be string, bytes or bytearray [type=json_type, input_value=12, input_type=int]
1472
+ '''
1473
+
1474
+ try:
1475
+ ConstrainedJsonModel(json_obj='[a, b]')
1476
+ except ValidationError as e:
1477
+ print(e)
1478
+ '''
1479
+ 1 validation error for ConstrainedJsonModel
1480
+ json_obj
1481
+ Invalid JSON: expected value at line 1 column 2 [type=json_invalid, input_value='[a, b]', input_type=str]
1482
+ '''
1483
+
1484
+ try:
1485
+ ConstrainedJsonModel(json_obj='["a", "b"]')
1486
+ except ValidationError as e:
1487
+ print(e)
1488
+ '''
1489
+ 2 validation errors for ConstrainedJsonModel
1490
+ json_obj.0
1491
+ Input should be a valid integer, unable to parse string as an integer [type=int_parsing, input_value='a', input_type=str]
1492
+ json_obj.1
1493
+ Input should be a valid integer, unable to parse string as an integer [type=int_parsing, input_value='b', input_type=str]
1494
+ '''
1495
+ ```
1496
+
1497
+ When you dump the model using `model_dump` or `model_dump_json`, the dumped value will be the result of validation,
1498
+ not the original JSON string. However, you can use the argument `round_trip=True` to get the original JSON string back:
1499
+
1500
+ ```python
1501
+ from pydantic import BaseModel, Json
1502
+
1503
+ class ConstrainedJsonModel(BaseModel):
1504
+ json_obj: Json[list[int]]
1505
+
1506
+ print(ConstrainedJsonModel(json_obj='[1, 2, 3]').model_dump_json())
1507
+ #> {"json_obj":[1,2,3]}
1508
+ print(
1509
+ ConstrainedJsonModel(json_obj='[1, 2, 3]').model_dump_json(round_trip=True)
1510
+ )
1511
+ #> {"json_obj":"[1,2,3]"}
1512
+ ```
1513
+ """
1514
+
1515
+ @classmethod
1516
+ def __class_getitem__(cls, item: AnyType) -> AnyType:
1517
+ return Annotated[item, cls()]
1518
+
1519
+ @classmethod
1520
+ def __get_pydantic_core_schema__(cls, source: Any, handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
1521
+ if cls is source:
1522
+ return core_schema.json_schema(None)
1523
+ else:
1524
+ return core_schema.json_schema(handler(source))
1525
+
1526
+ def __repr__(self) -> str:
1527
+ return 'Json'
1528
+
1529
+ def __hash__(self) -> int:
1530
+ return hash(type(self))
1531
+
1532
+ def __eq__(self, other: Any) -> bool:
1533
+ return type(other) is type(self)
1534
+
1535
+
1536
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ SECRET TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1537
+
1538
+ # The `Secret` class being conceptually immutable, make the type variable covariant:
1539
+ SecretType = TypeVar('SecretType', covariant=True)
1540
+
1541
+
1542
+ class _SecretBase(Generic[SecretType]):
1543
+ def __init__(self, secret_value: SecretType) -> None:
1544
+ self._secret_value: SecretType = secret_value
1545
+
1546
+ def get_secret_value(self) -> SecretType:
1547
+ """Get the secret value.
1548
+
1549
+ Returns:
1550
+ The secret value.
1551
+ """
1552
+ return self._secret_value
1553
+
1554
+ def __eq__(self, other: Any) -> bool:
1555
+ return isinstance(other, self.__class__) and self.get_secret_value() == other.get_secret_value()
1556
+
1557
+ def __hash__(self) -> int:
1558
+ return hash(self.get_secret_value())
1559
+
1560
+ def __str__(self) -> str:
1561
+ return str(self._display())
1562
+
1563
+ def __repr__(self) -> str:
1564
+ return f'{self.__class__.__name__}({self._display()!r})'
1565
+
1566
+ def _display(self) -> str | bytes:
1567
+ raise NotImplementedError
1568
+
1569
+
1570
+ def _serialize_secret(value: Secret[SecretType], info: core_schema.SerializationInfo) -> str | Secret[SecretType]:
1571
+ if info.mode == 'json':
1572
+ return str(value)
1573
+ else:
1574
+ return value
1575
+
1576
+
1577
+ class Secret(_SecretBase[SecretType]):
1578
+ """A generic base class used for defining a field with sensitive information that you do not want to be visible in logging or tracebacks.
1579
+
1580
+ You may either directly parametrize `Secret` with a type, or subclass from `Secret` with a parametrized type. The benefit of subclassing
1581
+ is that you can define a custom `_display` method, which will be used for `repr()` and `str()` methods. The examples below demonstrate both
1582
+ ways of using `Secret` to create a new secret type.
1583
+
1584
+ 1. Directly parametrizing `Secret` with a type:
1585
+
1586
+ ```python
1587
+ from pydantic import BaseModel, Secret
1588
+
1589
+ SecretBool = Secret[bool]
1590
+
1591
+ class Model(BaseModel):
1592
+ secret_bool: SecretBool
1593
+
1594
+ m = Model(secret_bool=True)
1595
+ print(m.model_dump())
1596
+ #> {'secret_bool': Secret('**********')}
1597
+
1598
+ print(m.model_dump_json())
1599
+ #> {"secret_bool":"**********"}
1600
+
1601
+ print(m.secret_bool.get_secret_value())
1602
+ #> True
1603
+ ```
1604
+
1605
+ 2. Subclassing from parametrized `Secret`:
1606
+
1607
+ ```python
1608
+ from datetime import date
1609
+
1610
+ from pydantic import BaseModel, Secret
1611
+
1612
+ class SecretDate(Secret[date]):
1613
+ def _display(self) -> str:
1614
+ return '****/**/**'
1615
+
1616
+ class Model(BaseModel):
1617
+ secret_date: SecretDate
1618
+
1619
+ m = Model(secret_date=date(2022, 1, 1))
1620
+ print(m.model_dump())
1621
+ #> {'secret_date': SecretDate('****/**/**')}
1622
+
1623
+ print(m.model_dump_json())
1624
+ #> {"secret_date":"****/**/**"}
1625
+
1626
+ print(m.secret_date.get_secret_value())
1627
+ #> 2022-01-01
1628
+ ```
1629
+
1630
+ The value returned by the `_display` method will be used for `repr()` and `str()`.
1631
+
1632
+ You can enforce constraints on the underlying type through annotations:
1633
+ For example:
1634
+
1635
+ ```python
1636
+ from typing import Annotated
1637
+
1638
+ from pydantic import BaseModel, Field, Secret, ValidationError
1639
+
1640
+ SecretPosInt = Secret[Annotated[int, Field(gt=0, strict=True)]]
1641
+
1642
+ class Model(BaseModel):
1643
+ sensitive_int: SecretPosInt
1644
+
1645
+ m = Model(sensitive_int=42)
1646
+ print(m.model_dump())
1647
+ #> {'sensitive_int': Secret('**********')}
1648
+
1649
+ try:
1650
+ m = Model(sensitive_int=-42) # (1)!
1651
+ except ValidationError as exc_info:
1652
+ print(exc_info.errors(include_url=False, include_input=False))
1653
+ '''
1654
+ [
1655
+ {
1656
+ 'type': 'greater_than',
1657
+ 'loc': ('sensitive_int',),
1658
+ 'msg': 'Input should be greater than 0',
1659
+ 'ctx': {'gt': 0},
1660
+ }
1661
+ ]
1662
+ '''
1663
+
1664
+ try:
1665
+ m = Model(sensitive_int='42') # (2)!
1666
+ except ValidationError as exc_info:
1667
+ print(exc_info.errors(include_url=False, include_input=False))
1668
+ '''
1669
+ [
1670
+ {
1671
+ 'type': 'int_type',
1672
+ 'loc': ('sensitive_int',),
1673
+ 'msg': 'Input should be a valid integer',
1674
+ }
1675
+ ]
1676
+ '''
1677
+ ```
1678
+
1679
+ 1. The input value is not greater than 0, so it raises a validation error.
1680
+ 2. The input value is not an integer, so it raises a validation error because the `SecretPosInt` type has strict mode enabled.
1681
+ """
1682
+
1683
+ def _display(self) -> str | bytes:
1684
+ return '**********' if self.get_secret_value() else ''
1685
+
1686
+ @classmethod
1687
+ def __get_pydantic_core_schema__(cls, source: type[Any], handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
1688
+ inner_type = None
1689
+ # if origin_type is Secret, then cls is a GenericAlias, and we can extract the inner type directly
1690
+ origin_type = get_origin(source)
1691
+ if origin_type is not None:
1692
+ inner_type = get_args(source)[0]
1693
+ # otherwise, we need to get the inner type from the base class
1694
+ else:
1695
+ bases = getattr(cls, '__orig_bases__', getattr(cls, '__bases__', []))
1696
+ for base in bases:
1697
+ if get_origin(base) is Secret:
1698
+ inner_type = get_args(base)[0]
1699
+ if bases == [] or inner_type is None:
1700
+ raise TypeError(
1701
+ f"Can't get secret type from {cls.__name__}. "
1702
+ 'Please use Secret[<type>], or subclass from Secret[<type>] instead.'
1703
+ )
1704
+
1705
+ inner_schema = handler.generate_schema(inner_type) # type: ignore
1706
+
1707
+ def validate_secret_value(value, handler) -> Secret[SecretType]:
1708
+ if isinstance(value, Secret):
1709
+ value = value.get_secret_value()
1710
+ validated_inner = handler(value)
1711
+ return cls(validated_inner)
1712
+
1713
+ return core_schema.json_or_python_schema(
1714
+ python_schema=core_schema.no_info_wrap_validator_function(
1715
+ validate_secret_value,
1716
+ inner_schema,
1717
+ ),
1718
+ json_schema=core_schema.no_info_after_validator_function(lambda x: cls(x), inner_schema),
1719
+ serialization=core_schema.plain_serializer_function_ser_schema(
1720
+ _serialize_secret,
1721
+ info_arg=True,
1722
+ when_used='always',
1723
+ ),
1724
+ )
1725
+
1726
+ __pydantic_serializer__ = SchemaSerializer(
1727
+ core_schema.any_schema(
1728
+ serialization=core_schema.plain_serializer_function_ser_schema(
1729
+ _serialize_secret,
1730
+ info_arg=True,
1731
+ when_used='always',
1732
+ )
1733
+ )
1734
+ )
1735
+
1736
+
1737
+ def _secret_display(value: SecretType) -> str: # type: ignore
1738
+ return '**********' if value else ''
1739
+
1740
+
1741
+ def _serialize_secret_field(
1742
+ value: _SecretField[SecretType], info: core_schema.SerializationInfo
1743
+ ) -> str | _SecretField[SecretType]:
1744
+ if info.mode == 'json':
1745
+ # we want the output to always be string without the `b'` prefix for bytes,
1746
+ # hence we just use `secret_display`
1747
+ return _secret_display(value.get_secret_value())
1748
+ else:
1749
+ return value
1750
+
1751
+
1752
+ class _SecretField(_SecretBase[SecretType]):
1753
+ _inner_schema: ClassVar[CoreSchema]
1754
+ _error_kind: ClassVar[str]
1755
+
1756
+ @classmethod
1757
+ def __get_pydantic_core_schema__(cls, source: type[Any], handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
1758
+ def get_json_schema(_core_schema: core_schema.CoreSchema, handler: GetJsonSchemaHandler) -> JsonSchemaValue:
1759
+ json_schema = handler(cls._inner_schema)
1760
+ _utils.update_not_none(
1761
+ json_schema,
1762
+ type='string',
1763
+ writeOnly=True,
1764
+ format='password',
1765
+ )
1766
+ return json_schema
1767
+
1768
+ def get_secret_schema(strict: bool) -> CoreSchema:
1769
+ inner_schema = {**cls._inner_schema, 'strict': strict}
1770
+ json_schema = core_schema.no_info_after_validator_function(
1771
+ source, # construct the type
1772
+ inner_schema, # pyright: ignore[reportArgumentType]
1773
+ )
1774
+ return core_schema.json_or_python_schema(
1775
+ python_schema=core_schema.union_schema(
1776
+ [
1777
+ core_schema.is_instance_schema(source),
1778
+ json_schema,
1779
+ ],
1780
+ custom_error_type=cls._error_kind,
1781
+ ),
1782
+ json_schema=json_schema,
1783
+ serialization=core_schema.plain_serializer_function_ser_schema(
1784
+ _serialize_secret_field,
1785
+ info_arg=True,
1786
+ when_used='always',
1787
+ ),
1788
+ )
1789
+
1790
+ return core_schema.lax_or_strict_schema(
1791
+ lax_schema=get_secret_schema(strict=False),
1792
+ strict_schema=get_secret_schema(strict=True),
1793
+ metadata={'pydantic_js_functions': [get_json_schema]},
1794
+ )
1795
+
1796
+ __pydantic_serializer__ = SchemaSerializer(
1797
+ core_schema.any_schema(
1798
+ serialization=core_schema.plain_serializer_function_ser_schema(
1799
+ _serialize_secret_field,
1800
+ info_arg=True,
1801
+ when_used='always',
1802
+ )
1803
+ )
1804
+ )
1805
+
1806
+
1807
+ class SecretStr(_SecretField[str]):
1808
+ """A string used for storing sensitive information that you do not want to be visible in logging or tracebacks.
1809
+
1810
+ When the secret value is nonempty, it is displayed as `'**********'` instead of the underlying value in
1811
+ calls to `repr()` and `str()`. If the value _is_ empty, it is displayed as `''`.
1812
+
1813
+ ```python
1814
+ from pydantic import BaseModel, SecretStr
1815
+
1816
+ class User(BaseModel):
1817
+ username: str
1818
+ password: SecretStr
1819
+
1820
+ user = User(username='scolvin', password='password1')
1821
+
1822
+ print(user)
1823
+ #> username='scolvin' password=SecretStr('**********')
1824
+ print(user.password.get_secret_value())
1825
+ #> password1
1826
+ print((SecretStr('password'), SecretStr('')))
1827
+ #> (SecretStr('**********'), SecretStr(''))
1828
+ ```
1829
+
1830
+ As seen above, by default, [`SecretStr`][pydantic.types.SecretStr] (and [`SecretBytes`][pydantic.types.SecretBytes])
1831
+ will be serialized as `**********` when serializing to json.
1832
+
1833
+ You can use the [`field_serializer`][pydantic.functional_serializers.field_serializer] to dump the
1834
+ secret as plain-text when serializing to json.
1835
+
1836
+ ```python
1837
+ from pydantic import BaseModel, SecretBytes, SecretStr, field_serializer
1838
+
1839
+ class Model(BaseModel):
1840
+ password: SecretStr
1841
+ password_bytes: SecretBytes
1842
+
1843
+ @field_serializer('password', 'password_bytes', when_used='json')
1844
+ def dump_secret(self, v):
1845
+ return v.get_secret_value()
1846
+
1847
+ model = Model(password='IAmSensitive', password_bytes=b'IAmSensitiveBytes')
1848
+ print(model)
1849
+ #> password=SecretStr('**********') password_bytes=SecretBytes(b'**********')
1850
+ print(model.password)
1851
+ #> **********
1852
+ print(model.model_dump())
1853
+ '''
1854
+ {
1855
+ 'password': SecretStr('**********'),
1856
+ 'password_bytes': SecretBytes(b'**********'),
1857
+ }
1858
+ '''
1859
+ print(model.model_dump_json())
1860
+ #> {"password":"IAmSensitive","password_bytes":"IAmSensitiveBytes"}
1861
+ ```
1862
+ """
1863
+
1864
+ _inner_schema: ClassVar[CoreSchema] = core_schema.str_schema()
1865
+ _error_kind: ClassVar[str] = 'string_type'
1866
+
1867
+ def __len__(self) -> int:
1868
+ return len(self._secret_value)
1869
+
1870
+ def _display(self) -> str:
1871
+ return _secret_display(self._secret_value)
1872
+
1873
+
1874
+ class SecretBytes(_SecretField[bytes]):
1875
+ """A bytes used for storing sensitive information that you do not want to be visible in logging or tracebacks.
1876
+
1877
+ It displays `b'**********'` instead of the string value on `repr()` and `str()` calls.
1878
+ When the secret value is nonempty, it is displayed as `b'**********'` instead of the underlying value in
1879
+ calls to `repr()` and `str()`. If the value _is_ empty, it is displayed as `b''`.
1880
+
1881
+ ```python
1882
+ from pydantic import BaseModel, SecretBytes
1883
+
1884
+ class User(BaseModel):
1885
+ username: str
1886
+ password: SecretBytes
1887
+
1888
+ user = User(username='scolvin', password=b'password1')
1889
+ #> username='scolvin' password=SecretBytes(b'**********')
1890
+ print(user.password.get_secret_value())
1891
+ #> b'password1'
1892
+ print((SecretBytes(b'password'), SecretBytes(b'')))
1893
+ #> (SecretBytes(b'**********'), SecretBytes(b''))
1894
+ ```
1895
+ """
1896
+
1897
+ _inner_schema: ClassVar[CoreSchema] = core_schema.bytes_schema()
1898
+ _error_kind: ClassVar[str] = 'bytes_type'
1899
+
1900
+ def __len__(self) -> int:
1901
+ return len(self._secret_value)
1902
+
1903
+ def _display(self) -> bytes:
1904
+ return _secret_display(self._secret_value).encode()
1905
+
1906
+
1907
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ PAYMENT CARD TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1908
+
1909
+
1910
+ class PaymentCardBrand(str, Enum):
1911
+ amex = 'American Express'
1912
+ mastercard = 'Mastercard'
1913
+ visa = 'Visa'
1914
+ other = 'other'
1915
+
1916
+ def __str__(self) -> str:
1917
+ return self.value
1918
+
1919
+
1920
+ @deprecated(
1921
+ 'The `PaymentCardNumber` class is deprecated, use `pydantic_extra_types` instead. '
1922
+ 'See https://docs.pydantic.dev/latest/api/pydantic_extra_types_payment/#pydantic_extra_types.payment.PaymentCardNumber.',
1923
+ category=PydanticDeprecatedSince20,
1924
+ )
1925
+ class PaymentCardNumber(str):
1926
+ """Based on: https://en.wikipedia.org/wiki/Payment_card_number."""
1927
+
1928
+ strip_whitespace: ClassVar[bool] = True
1929
+ min_length: ClassVar[int] = 12
1930
+ max_length: ClassVar[int] = 19
1931
+ bin: str
1932
+ last4: str
1933
+ brand: PaymentCardBrand
1934
+
1935
+ def __init__(self, card_number: str):
1936
+ self.validate_digits(card_number)
1937
+
1938
+ card_number = self.validate_luhn_check_digit(card_number)
1939
+
1940
+ self.bin = card_number[:6]
1941
+ self.last4 = card_number[-4:]
1942
+ self.brand = self.validate_brand(card_number)
1943
+
1944
+ @classmethod
1945
+ def __get_pydantic_core_schema__(cls, source: type[Any], handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
1946
+ return core_schema.with_info_after_validator_function(
1947
+ cls.validate,
1948
+ core_schema.str_schema(
1949
+ min_length=cls.min_length, max_length=cls.max_length, strip_whitespace=cls.strip_whitespace
1950
+ ),
1951
+ )
1952
+
1953
+ @classmethod
1954
+ def validate(cls, input_value: str, /, _: core_schema.ValidationInfo) -> PaymentCardNumber:
1955
+ """Validate the card number and return a `PaymentCardNumber` instance."""
1956
+ return cls(input_value)
1957
+
1958
+ @property
1959
+ def masked(self) -> str:
1960
+ """Mask all but the last 4 digits of the card number.
1961
+
1962
+ Returns:
1963
+ A masked card number string.
1964
+ """
1965
+ num_masked = len(self) - 10 # len(bin) + len(last4) == 10
1966
+ return f'{self.bin}{"*" * num_masked}{self.last4}'
1967
+
1968
+ @classmethod
1969
+ def validate_digits(cls, card_number: str) -> None:
1970
+ """Validate that the card number is all digits."""
1971
+ if not card_number.isdigit():
1972
+ raise PydanticCustomError('payment_card_number_digits', 'Card number is not all digits')
1973
+
1974
+ @classmethod
1975
+ def validate_luhn_check_digit(cls, card_number: str) -> str:
1976
+ """Based on: https://en.wikipedia.org/wiki/Luhn_algorithm."""
1977
+ sum_ = int(card_number[-1])
1978
+ length = len(card_number)
1979
+ parity = length % 2
1980
+ for i in range(length - 1):
1981
+ digit = int(card_number[i])
1982
+ if i % 2 == parity:
1983
+ digit *= 2
1984
+ if digit > 9:
1985
+ digit -= 9
1986
+ sum_ += digit
1987
+ valid = sum_ % 10 == 0
1988
+ if not valid:
1989
+ raise PydanticCustomError('payment_card_number_luhn', 'Card number is not luhn valid')
1990
+ return card_number
1991
+
1992
+ @staticmethod
1993
+ def validate_brand(card_number: str) -> PaymentCardBrand:
1994
+ """Validate length based on BIN for major brands:
1995
+ https://en.wikipedia.org/wiki/Payment_card_number#Issuer_identification_number_(IIN).
1996
+ """
1997
+ if card_number[0] == '4':
1998
+ brand = PaymentCardBrand.visa
1999
+ elif 51 <= int(card_number[:2]) <= 55:
2000
+ brand = PaymentCardBrand.mastercard
2001
+ elif card_number[:2] in {'34', '37'}:
2002
+ brand = PaymentCardBrand.amex
2003
+ else:
2004
+ brand = PaymentCardBrand.other
2005
+
2006
+ required_length: None | int | str = None
2007
+ if brand in PaymentCardBrand.mastercard:
2008
+ required_length = 16
2009
+ valid = len(card_number) == required_length
2010
+ elif brand == PaymentCardBrand.visa:
2011
+ required_length = '13, 16 or 19'
2012
+ valid = len(card_number) in {13, 16, 19}
2013
+ elif brand == PaymentCardBrand.amex:
2014
+ required_length = 15
2015
+ valid = len(card_number) == required_length
2016
+ else:
2017
+ valid = True
2018
+
2019
+ if not valid:
2020
+ raise PydanticCustomError(
2021
+ 'payment_card_number_brand',
2022
+ 'Length for a {brand} card must be {required_length}',
2023
+ {'brand': brand, 'required_length': required_length},
2024
+ )
2025
+ return brand
2026
+
2027
+
2028
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ BYTE SIZE TYPE ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2029
+
2030
+
2031
+ class ByteSize(int):
2032
+ """Converts a string representing a number of bytes with units (such as `'1KB'` or `'11.5MiB'`) into an integer.
2033
+
2034
+ You can use the `ByteSize` data type to (case-insensitively) convert a string representation of a number of bytes into
2035
+ an integer, and also to print out human-readable strings representing a number of bytes.
2036
+
2037
+ In conformance with [IEC 80000-13 Standard](https://en.wikipedia.org/wiki/ISO/IEC_80000) we interpret `'1KB'` to mean 1000 bytes,
2038
+ and `'1KiB'` to mean 1024 bytes. In general, including a middle `'i'` will cause the unit to be interpreted as a power of 2,
2039
+ rather than a power of 10 (so, for example, `'1 MB'` is treated as `1_000_000` bytes, whereas `'1 MiB'` is treated as `1_048_576` bytes).
2040
+
2041
+ !!! info
2042
+ Note that `1b` will be parsed as "1 byte" and not "1 bit".
2043
+
2044
+ ```python
2045
+ from pydantic import BaseModel, ByteSize
2046
+
2047
+ class MyModel(BaseModel):
2048
+ size: ByteSize
2049
+
2050
+ print(MyModel(size=52000).size)
2051
+ #> 52000
2052
+ print(MyModel(size='3000 KiB').size)
2053
+ #> 3072000
2054
+
2055
+ m = MyModel(size='50 PB')
2056
+ print(m.size.human_readable())
2057
+ #> 44.4PiB
2058
+ print(m.size.human_readable(decimal=True))
2059
+ #> 50.0PB
2060
+ print(m.size.human_readable(separator=' '))
2061
+ #> 44.4 PiB
2062
+
2063
+ print(m.size.to('TiB'))
2064
+ #> 45474.73508864641
2065
+ ```
2066
+ """
2067
+
2068
+ byte_sizes = {
2069
+ 'b': 1,
2070
+ 'kb': 10**3,
2071
+ 'mb': 10**6,
2072
+ 'gb': 10**9,
2073
+ 'tb': 10**12,
2074
+ 'pb': 10**15,
2075
+ 'eb': 10**18,
2076
+ 'kib': 2**10,
2077
+ 'mib': 2**20,
2078
+ 'gib': 2**30,
2079
+ 'tib': 2**40,
2080
+ 'pib': 2**50,
2081
+ 'eib': 2**60,
2082
+ 'bit': 1 / 8,
2083
+ 'kbit': 10**3 / 8,
2084
+ 'mbit': 10**6 / 8,
2085
+ 'gbit': 10**9 / 8,
2086
+ 'tbit': 10**12 / 8,
2087
+ 'pbit': 10**15 / 8,
2088
+ 'ebit': 10**18 / 8,
2089
+ 'kibit': 2**10 / 8,
2090
+ 'mibit': 2**20 / 8,
2091
+ 'gibit': 2**30 / 8,
2092
+ 'tibit': 2**40 / 8,
2093
+ 'pibit': 2**50 / 8,
2094
+ 'eibit': 2**60 / 8,
2095
+ }
2096
+ byte_sizes.update({k.lower()[0]: v for k, v in byte_sizes.items() if 'i' not in k})
2097
+
2098
+ byte_string_pattern = r'^\s*(\d*\.?\d+)\s*(\w+)?'
2099
+ byte_string_re = re.compile(byte_string_pattern, re.IGNORECASE)
2100
+
2101
+ @classmethod
2102
+ def __get_pydantic_core_schema__(cls, source: type[Any], handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
2103
+ return core_schema.with_info_after_validator_function(
2104
+ function=cls._validate,
2105
+ schema=core_schema.union_schema(
2106
+ [
2107
+ core_schema.str_schema(pattern=cls.byte_string_pattern),
2108
+ core_schema.int_schema(ge=0),
2109
+ ],
2110
+ custom_error_type='byte_size',
2111
+ custom_error_message='could not parse value and unit from byte string',
2112
+ ),
2113
+ serialization=core_schema.plain_serializer_function_ser_schema(
2114
+ int, return_schema=core_schema.int_schema(ge=0)
2115
+ ),
2116
+ )
2117
+
2118
+ @classmethod
2119
+ def _validate(cls, input_value: Any, /, _: core_schema.ValidationInfo) -> ByteSize:
2120
+ try:
2121
+ return cls(int(input_value))
2122
+ except ValueError:
2123
+ pass
2124
+
2125
+ str_match = cls.byte_string_re.match(str(input_value))
2126
+ if str_match is None:
2127
+ raise PydanticCustomError('byte_size', 'could not parse value and unit from byte string')
2128
+
2129
+ scalar, unit = str_match.groups()
2130
+ if unit is None:
2131
+ unit = 'b'
2132
+
2133
+ try:
2134
+ unit_mult = cls.byte_sizes[unit.lower()]
2135
+ except KeyError:
2136
+ raise PydanticCustomError('byte_size_unit', 'could not interpret byte unit: {unit}', {'unit': unit})
2137
+
2138
+ return cls(int(float(scalar) * unit_mult))
2139
+
2140
+ def human_readable(self, decimal: bool = False, separator: str = '') -> str:
2141
+ """Converts a byte size to a human readable string.
2142
+
2143
+ Args:
2144
+ decimal: If True, use decimal units (e.g. 1000 bytes per KB). If False, use binary units
2145
+ (e.g. 1024 bytes per KiB).
2146
+ separator: A string used to split the value and unit. Defaults to an empty string ('').
2147
+
2148
+ Returns:
2149
+ A human readable string representation of the byte size.
2150
+ """
2151
+ if decimal:
2152
+ divisor = 1000
2153
+ units = 'B', 'KB', 'MB', 'GB', 'TB', 'PB'
2154
+ final_unit = 'EB'
2155
+ else:
2156
+ divisor = 1024
2157
+ units = 'B', 'KiB', 'MiB', 'GiB', 'TiB', 'PiB'
2158
+ final_unit = 'EiB'
2159
+
2160
+ num = float(self)
2161
+ for unit in units:
2162
+ if abs(num) < divisor:
2163
+ if unit == 'B':
2164
+ return f'{num:0.0f}{separator}{unit}'
2165
+ else:
2166
+ return f'{num:0.1f}{separator}{unit}'
2167
+ num /= divisor
2168
+
2169
+ return f'{num:0.1f}{separator}{final_unit}'
2170
+
2171
+ def to(self, unit: str) -> float:
2172
+ """Converts a byte size to another unit, including both byte and bit units.
2173
+
2174
+ Args:
2175
+ unit: The unit to convert to. Must be one of the following: B, KB, MB, GB, TB, PB, EB,
2176
+ KiB, MiB, GiB, TiB, PiB, EiB (byte units) and
2177
+ bit, kbit, mbit, gbit, tbit, pbit, ebit,
2178
+ kibit, mibit, gibit, tibit, pibit, eibit (bit units).
2179
+
2180
+ Returns:
2181
+ The byte size in the new unit.
2182
+ """
2183
+ try:
2184
+ unit_div = self.byte_sizes[unit.lower()]
2185
+ except KeyError:
2186
+ raise PydanticCustomError('byte_size_unit', 'Could not interpret byte unit: {unit}', {'unit': unit})
2187
+
2188
+ return self / unit_div
2189
+
2190
+
2191
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ DATE TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2192
+
2193
+
2194
+ def _check_annotated_type(annotated_type: str, expected_type: str, annotation: str) -> None:
2195
+ if annotated_type != expected_type:
2196
+ raise PydanticUserError(f"'{annotation}' cannot annotate '{annotated_type}'.", code='invalid-annotated-type')
2197
+
2198
+
2199
+ if TYPE_CHECKING:
2200
+ PastDate = Annotated[date, ...]
2201
+ FutureDate = Annotated[date, ...]
2202
+ else:
2203
+
2204
+ class PastDate:
2205
+ """A date in the past."""
2206
+
2207
+ @classmethod
2208
+ def __get_pydantic_core_schema__(
2209
+ cls, source: type[Any], handler: GetCoreSchemaHandler
2210
+ ) -> core_schema.CoreSchema:
2211
+ if cls is source:
2212
+ # used directly as a type
2213
+ return core_schema.date_schema(now_op='past')
2214
+ else:
2215
+ schema = handler(source)
2216
+ _check_annotated_type(schema['type'], 'date', cls.__name__)
2217
+ schema['now_op'] = 'past'
2218
+ return schema
2219
+
2220
+ def __repr__(self) -> str:
2221
+ return 'PastDate'
2222
+
2223
+ class FutureDate:
2224
+ """A date in the future."""
2225
+
2226
+ @classmethod
2227
+ def __get_pydantic_core_schema__(
2228
+ cls, source: type[Any], handler: GetCoreSchemaHandler
2229
+ ) -> core_schema.CoreSchema:
2230
+ if cls is source:
2231
+ # used directly as a type
2232
+ return core_schema.date_schema(now_op='future')
2233
+ else:
2234
+ schema = handler(source)
2235
+ _check_annotated_type(schema['type'], 'date', cls.__name__)
2236
+ schema['now_op'] = 'future'
2237
+ return schema
2238
+
2239
+ def __repr__(self) -> str:
2240
+ return 'FutureDate'
2241
+
2242
+
2243
+ def condate(
2244
+ *,
2245
+ strict: bool | None = None,
2246
+ gt: date | None = None,
2247
+ ge: date | None = None,
2248
+ lt: date | None = None,
2249
+ le: date | None = None,
2250
+ ) -> type[date]:
2251
+ """A wrapper for date that adds constraints.
2252
+
2253
+ Args:
2254
+ strict: Whether to validate the date value in strict mode. Defaults to `None`.
2255
+ gt: The value must be greater than this. Defaults to `None`.
2256
+ ge: The value must be greater than or equal to this. Defaults to `None`.
2257
+ lt: The value must be less than this. Defaults to `None`.
2258
+ le: The value must be less than or equal to this. Defaults to `None`.
2259
+
2260
+ Returns:
2261
+ A date type with the specified constraints.
2262
+ """
2263
+ return Annotated[ # pyright: ignore[reportReturnType]
2264
+ date,
2265
+ Strict(strict) if strict is not None else None,
2266
+ annotated_types.Interval(gt=gt, ge=ge, lt=lt, le=le),
2267
+ ]
2268
+
2269
+
2270
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ DATETIME TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2271
+
2272
+ if TYPE_CHECKING:
2273
+ AwareDatetime = Annotated[datetime, ...]
2274
+ NaiveDatetime = Annotated[datetime, ...]
2275
+ PastDatetime = Annotated[datetime, ...]
2276
+ FutureDatetime = Annotated[datetime, ...]
2277
+
2278
+ else:
2279
+
2280
+ class AwareDatetime:
2281
+ """A datetime that requires timezone info."""
2282
+
2283
+ @classmethod
2284
+ def __get_pydantic_core_schema__(
2285
+ cls, source: type[Any], handler: GetCoreSchemaHandler
2286
+ ) -> core_schema.CoreSchema:
2287
+ if cls is source:
2288
+ # used directly as a type
2289
+ return core_schema.datetime_schema(tz_constraint='aware')
2290
+ else:
2291
+ schema = handler(source)
2292
+ _check_annotated_type(schema['type'], 'datetime', cls.__name__)
2293
+ schema['tz_constraint'] = 'aware'
2294
+ return schema
2295
+
2296
+ def __repr__(self) -> str:
2297
+ return 'AwareDatetime'
2298
+
2299
+ class NaiveDatetime:
2300
+ """A datetime that doesn't require timezone info."""
2301
+
2302
+ @classmethod
2303
+ def __get_pydantic_core_schema__(
2304
+ cls, source: type[Any], handler: GetCoreSchemaHandler
2305
+ ) -> core_schema.CoreSchema:
2306
+ if cls is source:
2307
+ # used directly as a type
2308
+ return core_schema.datetime_schema(tz_constraint='naive')
2309
+ else:
2310
+ schema = handler(source)
2311
+ _check_annotated_type(schema['type'], 'datetime', cls.__name__)
2312
+ schema['tz_constraint'] = 'naive'
2313
+ return schema
2314
+
2315
+ def __repr__(self) -> str:
2316
+ return 'NaiveDatetime'
2317
+
2318
+ class PastDatetime:
2319
+ """A datetime that must be in the past."""
2320
+
2321
+ @classmethod
2322
+ def __get_pydantic_core_schema__(
2323
+ cls, source: type[Any], handler: GetCoreSchemaHandler
2324
+ ) -> core_schema.CoreSchema:
2325
+ if cls is source:
2326
+ # used directly as a type
2327
+ return core_schema.datetime_schema(now_op='past')
2328
+ else:
2329
+ schema = handler(source)
2330
+ _check_annotated_type(schema['type'], 'datetime', cls.__name__)
2331
+ schema['now_op'] = 'past'
2332
+ return schema
2333
+
2334
+ def __repr__(self) -> str:
2335
+ return 'PastDatetime'
2336
+
2337
+ class FutureDatetime:
2338
+ """A datetime that must be in the future."""
2339
+
2340
+ @classmethod
2341
+ def __get_pydantic_core_schema__(
2342
+ cls, source: type[Any], handler: GetCoreSchemaHandler
2343
+ ) -> core_schema.CoreSchema:
2344
+ if cls is source:
2345
+ # used directly as a type
2346
+ return core_schema.datetime_schema(now_op='future')
2347
+ else:
2348
+ schema = handler(source)
2349
+ _check_annotated_type(schema['type'], 'datetime', cls.__name__)
2350
+ schema['now_op'] = 'future'
2351
+ return schema
2352
+
2353
+ def __repr__(self) -> str:
2354
+ return 'FutureDatetime'
2355
+
2356
+
2357
+ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Encoded TYPES ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2358
+
2359
+
2360
+ class EncoderProtocol(Protocol):
2361
+ """Protocol for encoding and decoding data to and from bytes."""
2362
+
2363
+ @classmethod
2364
+ def decode(cls, data: bytes) -> bytes:
2365
+ """Decode the data using the encoder.
2366
+
2367
+ Args:
2368
+ data: The data to decode.
2369
+
2370
+ Returns:
2371
+ The decoded data.
2372
+ """
2373
+ ...
2374
+
2375
+ @classmethod
2376
+ def encode(cls, value: bytes) -> bytes:
2377
+ """Encode the data using the encoder.
2378
+
2379
+ Args:
2380
+ value: The data to encode.
2381
+
2382
+ Returns:
2383
+ The encoded data.
2384
+ """
2385
+ ...
2386
+
2387
+ @classmethod
2388
+ def get_json_format(cls) -> str:
2389
+ """Get the JSON format for the encoded data.
2390
+
2391
+ Returns:
2392
+ The JSON format for the encoded data.
2393
+ """
2394
+ ...
2395
+
2396
+
2397
+ class Base64Encoder(EncoderProtocol):
2398
+ """Standard (non-URL-safe) Base64 encoder."""
2399
+
2400
+ @classmethod
2401
+ def decode(cls, data: bytes) -> bytes:
2402
+ """Decode the data from base64 encoded bytes to original bytes data.
2403
+
2404
+ Args:
2405
+ data: The data to decode.
2406
+
2407
+ Returns:
2408
+ The decoded data.
2409
+ """
2410
+ try:
2411
+ return base64.b64decode(data)
2412
+ except ValueError as e:
2413
+ raise PydanticCustomError('base64_decode', "Base64 decoding error: '{error}'", {'error': str(e)})
2414
+
2415
+ @classmethod
2416
+ def encode(cls, value: bytes) -> bytes:
2417
+ """Encode the data from bytes to a base64 encoded bytes.
2418
+
2419
+ Args:
2420
+ value: The data to encode.
2421
+
2422
+ Returns:
2423
+ The encoded data.
2424
+ """
2425
+ return base64.b64encode(value)
2426
+
2427
+ @classmethod
2428
+ def get_json_format(cls) -> Literal['base64']:
2429
+ """Get the JSON format for the encoded data.
2430
+
2431
+ Returns:
2432
+ The JSON format for the encoded data.
2433
+ """
2434
+ return 'base64'
2435
+
2436
+
2437
+ class Base64UrlEncoder(EncoderProtocol):
2438
+ """URL-safe Base64 encoder."""
2439
+
2440
+ @classmethod
2441
+ def decode(cls, data: bytes) -> bytes:
2442
+ """Decode the data from base64 encoded bytes to original bytes data.
2443
+
2444
+ Args:
2445
+ data: The data to decode.
2446
+
2447
+ Returns:
2448
+ The decoded data.
2449
+ """
2450
+ try:
2451
+ return base64.urlsafe_b64decode(data)
2452
+ except ValueError as e:
2453
+ raise PydanticCustomError('base64_decode', "Base64 decoding error: '{error}'", {'error': str(e)})
2454
+
2455
+ @classmethod
2456
+ def encode(cls, value: bytes) -> bytes:
2457
+ """Encode the data from bytes to a base64 encoded bytes.
2458
+
2459
+ Args:
2460
+ value: The data to encode.
2461
+
2462
+ Returns:
2463
+ The encoded data.
2464
+ """
2465
+ return base64.urlsafe_b64encode(value)
2466
+
2467
+ @classmethod
2468
+ def get_json_format(cls) -> Literal['base64url']:
2469
+ """Get the JSON format for the encoded data.
2470
+
2471
+ Returns:
2472
+ The JSON format for the encoded data.
2473
+ """
2474
+ return 'base64url'
2475
+
2476
+
2477
+ @_dataclasses.dataclass(**_internal_dataclass.slots_true)
2478
+ class EncodedBytes:
2479
+ """A bytes type that is encoded and decoded using the specified encoder.
2480
+
2481
+ `EncodedBytes` needs an encoder that implements `EncoderProtocol` to operate.
2482
+
2483
+ ```python
2484
+ from typing import Annotated
2485
+
2486
+ from pydantic import BaseModel, EncodedBytes, EncoderProtocol, ValidationError
2487
+
2488
+ class MyEncoder(EncoderProtocol):
2489
+ @classmethod
2490
+ def decode(cls, data: bytes) -> bytes:
2491
+ if data == b'**undecodable**':
2492
+ raise ValueError('Cannot decode data')
2493
+ return data[13:]
2494
+
2495
+ @classmethod
2496
+ def encode(cls, value: bytes) -> bytes:
2497
+ return b'**encoded**: ' + value
2498
+
2499
+ @classmethod
2500
+ def get_json_format(cls) -> str:
2501
+ return 'my-encoder'
2502
+
2503
+ MyEncodedBytes = Annotated[bytes, EncodedBytes(encoder=MyEncoder)]
2504
+
2505
+ class Model(BaseModel):
2506
+ my_encoded_bytes: MyEncodedBytes
2507
+
2508
+ # Initialize the model with encoded data
2509
+ m = Model(my_encoded_bytes=b'**encoded**: some bytes')
2510
+
2511
+ # Access decoded value
2512
+ print(m.my_encoded_bytes)
2513
+ #> b'some bytes'
2514
+
2515
+ # Serialize into the encoded form
2516
+ print(m.model_dump())
2517
+ #> {'my_encoded_bytes': b'**encoded**: some bytes'}
2518
+
2519
+ # Validate encoded data
2520
+ try:
2521
+ Model(my_encoded_bytes=b'**undecodable**')
2522
+ except ValidationError as e:
2523
+ print(e)
2524
+ '''
2525
+ 1 validation error for Model
2526
+ my_encoded_bytes
2527
+ Value error, Cannot decode data [type=value_error, input_value=b'**undecodable**', input_type=bytes]
2528
+ '''
2529
+ ```
2530
+ """
2531
+
2532
+ encoder: type[EncoderProtocol]
2533
+
2534
+ def __get_pydantic_json_schema__(
2535
+ self, core_schema: core_schema.CoreSchema, handler: GetJsonSchemaHandler
2536
+ ) -> JsonSchemaValue:
2537
+ field_schema = handler(core_schema)
2538
+ field_schema.update(type='string', format=self.encoder.get_json_format())
2539
+ return field_schema
2540
+
2541
+ def __get_pydantic_core_schema__(self, source: type[Any], handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
2542
+ schema = handler(source)
2543
+ _check_annotated_type(schema['type'], 'bytes', self.__class__.__name__)
2544
+ return core_schema.with_info_after_validator_function(
2545
+ function=self.decode,
2546
+ schema=schema,
2547
+ serialization=core_schema.plain_serializer_function_ser_schema(function=self.encode),
2548
+ )
2549
+
2550
+ def decode(self, data: bytes, _: core_schema.ValidationInfo) -> bytes:
2551
+ """Decode the data using the specified encoder.
2552
+
2553
+ Args:
2554
+ data: The data to decode.
2555
+
2556
+ Returns:
2557
+ The decoded data.
2558
+ """
2559
+ return self.encoder.decode(data)
2560
+
2561
+ def encode(self, value: bytes) -> bytes:
2562
+ """Encode the data using the specified encoder.
2563
+
2564
+ Args:
2565
+ value: The data to encode.
2566
+
2567
+ Returns:
2568
+ The encoded data.
2569
+ """
2570
+ return self.encoder.encode(value)
2571
+
2572
+ def __hash__(self) -> int:
2573
+ return hash(self.encoder)
2574
+
2575
+
2576
+ @_dataclasses.dataclass(**_internal_dataclass.slots_true)
2577
+ class EncodedStr:
2578
+ """A str type that is encoded and decoded using the specified encoder.
2579
+
2580
+ `EncodedStr` needs an encoder that implements `EncoderProtocol` to operate.
2581
+
2582
+ ```python
2583
+ from typing import Annotated
2584
+
2585
+ from pydantic import BaseModel, EncodedStr, EncoderProtocol, ValidationError
2586
+
2587
+ class MyEncoder(EncoderProtocol):
2588
+ @classmethod
2589
+ def decode(cls, data: bytes) -> bytes:
2590
+ if data == b'**undecodable**':
2591
+ raise ValueError('Cannot decode data')
2592
+ return data[13:]
2593
+
2594
+ @classmethod
2595
+ def encode(cls, value: bytes) -> bytes:
2596
+ return b'**encoded**: ' + value
2597
+
2598
+ @classmethod
2599
+ def get_json_format(cls) -> str:
2600
+ return 'my-encoder'
2601
+
2602
+ MyEncodedStr = Annotated[str, EncodedStr(encoder=MyEncoder)]
2603
+
2604
+ class Model(BaseModel):
2605
+ my_encoded_str: MyEncodedStr
2606
+
2607
+ # Initialize the model with encoded data
2608
+ m = Model(my_encoded_str='**encoded**: some str')
2609
+
2610
+ # Access decoded value
2611
+ print(m.my_encoded_str)
2612
+ #> some str
2613
+
2614
+ # Serialize into the encoded form
2615
+ print(m.model_dump())
2616
+ #> {'my_encoded_str': '**encoded**: some str'}
2617
+
2618
+ # Validate encoded data
2619
+ try:
2620
+ Model(my_encoded_str='**undecodable**')
2621
+ except ValidationError as e:
2622
+ print(e)
2623
+ '''
2624
+ 1 validation error for Model
2625
+ my_encoded_str
2626
+ Value error, Cannot decode data [type=value_error, input_value='**undecodable**', input_type=str]
2627
+ '''
2628
+ ```
2629
+ """
2630
+
2631
+ encoder: type[EncoderProtocol]
2632
+
2633
+ def __get_pydantic_json_schema__(
2634
+ self, core_schema: core_schema.CoreSchema, handler: GetJsonSchemaHandler
2635
+ ) -> JsonSchemaValue:
2636
+ field_schema = handler(core_schema)
2637
+ field_schema.update(type='string', format=self.encoder.get_json_format())
2638
+ return field_schema
2639
+
2640
+ def __get_pydantic_core_schema__(self, source: type[Any], handler: GetCoreSchemaHandler) -> core_schema.CoreSchema:
2641
+ schema = handler(source)
2642
+ _check_annotated_type(schema['type'], 'str', self.__class__.__name__)
2643
+ return core_schema.with_info_after_validator_function(
2644
+ function=self.decode_str,
2645
+ schema=schema,
2646
+ serialization=core_schema.plain_serializer_function_ser_schema(function=self.encode_str),
2647
+ )
2648
+
2649
+ def decode_str(self, data: str, _: core_schema.ValidationInfo) -> str:
2650
+ """Decode the data using the specified encoder.
2651
+
2652
+ Args:
2653
+ data: The data to decode.
2654
+
2655
+ Returns:
2656
+ The decoded data.
2657
+ """
2658
+ return self.encoder.decode(data.encode()).decode()
2659
+
2660
+ def encode_str(self, value: str) -> str:
2661
+ """Encode the data using the specified encoder.
2662
+
2663
+ Args:
2664
+ value: The data to encode.
2665
+
2666
+ Returns:
2667
+ The encoded data.
2668
+ """
2669
+ return self.encoder.encode(value.encode()).decode() # noqa: UP008
2670
+
2671
+ def __hash__(self) -> int:
2672
+ return hash(self.encoder)
2673
+
2674
+
2675
+ Base64Bytes = Annotated[bytes, EncodedBytes(encoder=Base64Encoder)]
2676
+ """A bytes type that is encoded and decoded using the standard (non-URL-safe) base64 encoder.
2677
+
2678
+ Note:
2679
+ Under the hood, `Base64Bytes` uses the standard library [`base64.b64encode()`][base64.b64encode] and [`base64.b64decode()`][base64.b64decode] functions.
2680
+
2681
+ As a result, attempting to decode url-safe base64 data using the `Base64Bytes` type may fail or produce an incorrect
2682
+ decoding.
2683
+
2684
+ /// version-changed | v2.10
2685
+ `Base64Bytes` now uses [`base64.b64encode()`][base64.b64encode] and [`base64.b64decode()`][base64.b64decode]
2686
+ instead of [`base64.encodebytes()`][base64.encodebytes] and [`base64.decodebytes()`][base64.decodebytes].
2687
+
2688
+ These methods are considered legacy implementation. If you'd still like to use these legacy encoders/decoders,
2689
+ you can achieve this by creating a custom annotated type, like follows:
2690
+ ```python
2691
+ import base64
2692
+ from typing import Annotated, Literal
2693
+
2694
+ from pydantic_core import PydanticCustomError
2695
+
2696
+ from pydantic import EncodedBytes, EncoderProtocol
2697
+
2698
+ class LegacyBase64Encoder(EncoderProtocol):
2699
+ @classmethod
2700
+ def decode(cls, data: bytes) -> bytes:
2701
+ try:
2702
+ return base64.decodebytes(data)
2703
+ except ValueError as e:
2704
+ raise PydanticCustomError(
2705
+ 'base64_decode',
2706
+ "Base64 decoding error: '{error}'",
2707
+ {'error': str(e)},
2708
+ )
2709
+
2710
+ @classmethod
2711
+ def encode(cls, value: bytes) -> bytes:
2712
+ return base64.encodebytes(value)
2713
+
2714
+ @classmethod
2715
+ def get_json_format(cls) -> Literal['base64']:
2716
+ return 'base64'
2717
+
2718
+ LegacyBase64Bytes = Annotated[bytes, EncodedBytes(encoder=LegacyBase64Encoder)]
2719
+ ```
2720
+ ///
2721
+
2722
+ ```python
2723
+ from pydantic import Base64Bytes, BaseModel, ValidationError
2724
+
2725
+ class Model(BaseModel):
2726
+ base64_bytes: Base64Bytes
2727
+
2728
+ # Initialize the model with base64 data
2729
+ m = Model(base64_bytes=b'VGhpcyBpcyB0aGUgd2F5')
2730
+
2731
+ # Access decoded value
2732
+ print(m.base64_bytes)
2733
+ #> b'This is the way'
2734
+
2735
+ # Serialize into the base64 form
2736
+ print(m.model_dump())
2737
+ #> {'base64_bytes': b'VGhpcyBpcyB0aGUgd2F5'}
2738
+
2739
+ # Validate base64 data
2740
+ try:
2741
+ print(Model(base64_bytes=b'undecodable').base64_bytes)
2742
+ except ValidationError as e:
2743
+ print(e)
2744
+ '''
2745
+ 1 validation error for Model
2746
+ base64_bytes
2747
+ Base64 decoding error: 'Incorrect padding' [type=base64_decode, input_value=b'undecodable', input_type=bytes]
2748
+ '''
2749
+ ```
2750
+ """
2751
+ Base64Str = Annotated[str, EncodedStr(encoder=Base64Encoder)]
2752
+ """A string type that is encoded and decoded using the standard (non-URL-safe) base64 encoder.
2753
+
2754
+ Note:
2755
+ Under the hood, `Base64Str` uses the standard library [`base64.b64encode()`][base64.b64encode] and [`base64.b64decode()`][base64.b64decode] functions.
2756
+
2757
+ As a result, attempting to decode url-safe base64 data using the `Base64Str` type may fail or produce an incorrect
2758
+ decoding.
2759
+
2760
+ /// version-changed | v2.10
2761
+ `Base64Str` now uses [`base64.b64encode()`][base64.b64encode] and [`base64.b64decode()`][base64.b64decode]
2762
+ instead of [`base64.encodebytes()`][base64.encodebytes] and [`base64.decodebytes()`][base64.decodebytes].
2763
+
2764
+ These methods are considered legacy implementation. See the documentation about the [`Base64Bytes`][pydantic.types.Base64Bytes] type
2765
+ for more information on how to replicate the old behavior with the legacy encoders/decoders.
2766
+ ///
2767
+
2768
+
2769
+ ```python
2770
+ from pydantic import Base64Str, BaseModel, ValidationError
2771
+
2772
+ class Model(BaseModel):
2773
+ base64_str: Base64Str
2774
+
2775
+ # Initialize the model with base64 data
2776
+ m = Model(base64_str='VGhlc2UgYXJlbid0IHRoZSBkcm9pZHMgeW91J3JlIGxvb2tpbmcgZm9y')
2777
+
2778
+ # Access decoded value
2779
+ print(m.base64_str)
2780
+ #> These aren't the droids you're looking for
2781
+
2782
+ # Serialize into the base64 form
2783
+ print(m.model_dump())
2784
+ #> {'base64_str': 'VGhlc2UgYXJlbid0IHRoZSBkcm9pZHMgeW91J3JlIGxvb2tpbmcgZm9y'}
2785
+
2786
+ # Validate base64 data
2787
+ try:
2788
+ print(Model(base64_str='undecodable').base64_str)
2789
+ except ValidationError as e:
2790
+ print(e)
2791
+ '''
2792
+ 1 validation error for Model
2793
+ base64_str
2794
+ Base64 decoding error: 'Incorrect padding' [type=base64_decode, input_value='undecodable', input_type=str]
2795
+ '''
2796
+ ```
2797
+ """
2798
+ Base64UrlBytes = Annotated[bytes, EncodedBytes(encoder=Base64UrlEncoder)]
2799
+ """A bytes type that is encoded and decoded using the URL-safe base64 encoder.
2800
+
2801
+ Note:
2802
+ Under the hood, `Base64UrlBytes` use standard library `base64.urlsafe_b64encode` and `base64.urlsafe_b64decode`
2803
+ functions.
2804
+
2805
+ As a result, the `Base64UrlBytes` type can be used to faithfully decode "vanilla" base64 data
2806
+ (using `'+'` and `'/'`).
2807
+
2808
+ ```python
2809
+ from pydantic import Base64UrlBytes, BaseModel
2810
+
2811
+ class Model(BaseModel):
2812
+ base64url_bytes: Base64UrlBytes
2813
+
2814
+ # Initialize the model with base64 data
2815
+ m = Model(base64url_bytes=b'SHc_dHc-TXc==')
2816
+ print(m)
2817
+ #> base64url_bytes=b'Hw?tw>Mw'
2818
+ ```
2819
+ """
2820
+ Base64UrlStr = Annotated[str, EncodedStr(encoder=Base64UrlEncoder)]
2821
+ """A str type that is encoded and decoded using the URL-safe base64 encoder.
2822
+
2823
+ Note:
2824
+ Under the hood, `Base64UrlStr` use standard library `base64.urlsafe_b64encode` and `base64.urlsafe_b64decode`
2825
+ functions.
2826
+
2827
+ As a result, the `Base64UrlStr` type can be used to faithfully decode "vanilla" base64 data (using `'+'` and `'/'`).
2828
+
2829
+ ```python
2830
+ from pydantic import Base64UrlStr, BaseModel
2831
+
2832
+ class Model(BaseModel):
2833
+ base64url_str: Base64UrlStr
2834
+
2835
+ # Initialize the model with base64 data
2836
+ m = Model(base64url_str='SHc_dHc-TXc==')
2837
+ print(m)
2838
+ #> base64url_str='Hw?tw>Mw'
2839
+ ```
2840
+ """
2841
+
2842
+
2843
+ __getattr__ = getattr_migration(__name__)
2844
+
2845
+
2846
+ @_dataclasses.dataclass(**_internal_dataclass.slots_true)
2847
+ class GetPydanticSchema:
2848
+ """!!! abstract "Usage Documentation"
2849
+ [Using `GetPydanticSchema` to Reduce Boilerplate](../concepts/types.md#using-getpydanticschema-to-reduce-boilerplate)
2850
+
2851
+ A convenience class for creating an annotation that provides pydantic custom type hooks.
2852
+
2853
+ This class is intended to eliminate the need to create a custom "marker" which defines the
2854
+ `__get_pydantic_core_schema__` and `__get_pydantic_json_schema__` custom hook methods.
2855
+
2856
+ For example, to have a field treated by type checkers as `int`, but by pydantic as `Any`, you can do:
2857
+ ```python
2858
+ from typing import Annotated, Any
2859
+
2860
+ from pydantic import BaseModel, GetPydanticSchema
2861
+
2862
+ HandleAsAny = GetPydanticSchema(lambda _s, h: h(Any))
2863
+
2864
+ class Model(BaseModel):
2865
+ x: Annotated[int, HandleAsAny] # pydantic sees `x: Any`
2866
+
2867
+ print(repr(Model(x='abc').x))
2868
+ #> 'abc'
2869
+ ```
2870
+ """
2871
+
2872
+ get_pydantic_core_schema: Callable[[Any, GetCoreSchemaHandler], CoreSchema] | None = None
2873
+ get_pydantic_json_schema: Callable[[Any, GetJsonSchemaHandler], JsonSchemaValue] | None = None
2874
+
2875
+ # Note: we may want to consider adding a convenience staticmethod `def for_type(type_: Any) -> GetPydanticSchema:`
2876
+ # which returns `GetPydanticSchema(lambda _s, h: h(type_))`
2877
+
2878
+ if not TYPE_CHECKING:
2879
+ # We put `__getattr__` in a non-TYPE_CHECKING block because otherwise, mypy allows arbitrary attribute access
2880
+
2881
+ def __getattr__(self, item: str) -> Any:
2882
+ """Use this rather than defining `__get_pydantic_core_schema__` etc. to reduce the number of nested calls."""
2883
+ if item == '__get_pydantic_core_schema__' and self.get_pydantic_core_schema:
2884
+ return self.get_pydantic_core_schema
2885
+ elif item == '__get_pydantic_json_schema__' and self.get_pydantic_json_schema:
2886
+ return self.get_pydantic_json_schema
2887
+ else:
2888
+ return object.__getattribute__(self, item)
2889
+
2890
+ __hash__ = object.__hash__
2891
+
2892
+
2893
+ @_dataclasses.dataclass(**_internal_dataclass.slots_true, frozen=True)
2894
+ class Tag:
2895
+ """Provides a way to specify the expected tag to use for a case of a (callable) discriminated union.
2896
+
2897
+ Also provides a way to label a union case in error messages.
2898
+
2899
+ When using a callable `Discriminator`, attach a `Tag` to each case in the `Union` to specify the tag that
2900
+ should be used to identify that case. For example, in the below example, the `Tag` is used to specify that
2901
+ if `get_discriminator_value` returns `'apple'`, the input should be validated as an `ApplePie`, and if it
2902
+ returns `'pumpkin'`, the input should be validated as a `PumpkinPie`.
2903
+
2904
+ The primary role of the `Tag` here is to map the return value from the callable `Discriminator` function to
2905
+ the appropriate member of the `Union` in question.
2906
+
2907
+ ```python
2908
+ from typing import Annotated, Any, Literal, Union
2909
+
2910
+ from pydantic import BaseModel, Discriminator, Tag
2911
+
2912
+ class Pie(BaseModel):
2913
+ time_to_cook: int
2914
+ num_ingredients: int
2915
+
2916
+ class ApplePie(Pie):
2917
+ fruit: Literal['apple'] = 'apple'
2918
+
2919
+ class PumpkinPie(Pie):
2920
+ filling: Literal['pumpkin'] = 'pumpkin'
2921
+
2922
+ def get_discriminator_value(v: Any) -> str:
2923
+ if isinstance(v, dict):
2924
+ return v.get('fruit', v.get('filling'))
2925
+ return getattr(v, 'fruit', getattr(v, 'filling', None))
2926
+
2927
+ class ThanksgivingDinner(BaseModel):
2928
+ dessert: Annotated[
2929
+ Union[
2930
+ Annotated[ApplePie, Tag('apple')],
2931
+ Annotated[PumpkinPie, Tag('pumpkin')],
2932
+ ],
2933
+ Discriminator(get_discriminator_value),
2934
+ ]
2935
+
2936
+ apple_variation = ThanksgivingDinner.model_validate(
2937
+ {'dessert': {'fruit': 'apple', 'time_to_cook': 60, 'num_ingredients': 8}}
2938
+ )
2939
+ print(repr(apple_variation))
2940
+ '''
2941
+ ThanksgivingDinner(dessert=ApplePie(time_to_cook=60, num_ingredients=8, fruit='apple'))
2942
+ '''
2943
+
2944
+ pumpkin_variation = ThanksgivingDinner.model_validate(
2945
+ {
2946
+ 'dessert': {
2947
+ 'filling': 'pumpkin',
2948
+ 'time_to_cook': 40,
2949
+ 'num_ingredients': 6,
2950
+ }
2951
+ }
2952
+ )
2953
+ print(repr(pumpkin_variation))
2954
+ '''
2955
+ ThanksgivingDinner(dessert=PumpkinPie(time_to_cook=40, num_ingredients=6, filling='pumpkin'))
2956
+ '''
2957
+ ```
2958
+
2959
+ !!! note
2960
+ You must specify a `Tag` for every case in a `Tag` that is associated with a
2961
+ callable `Discriminator`. Failing to do so will result in a `PydanticUserError` with code
2962
+ [`callable-discriminator-no-tag`](../errors/usage_errors.md#callable-discriminator-no-tag).
2963
+
2964
+ See the [Discriminated Unions] concepts docs for more details on how to use `Tag`s.
2965
+
2966
+ [Discriminated Unions]: ../concepts/unions.md#discriminated-unions
2967
+ """
2968
+
2969
+ tag: str
2970
+
2971
+ def __get_pydantic_core_schema__(self, source_type: Any, handler: GetCoreSchemaHandler) -> CoreSchema:
2972
+ schema = handler(source_type)
2973
+ metadata = cast('CoreMetadata', schema.setdefault('metadata', {}))
2974
+ metadata['pydantic_internal_union_tag_key'] = self.tag
2975
+ return schema
2976
+
2977
+
2978
+ @_dataclasses.dataclass(**_internal_dataclass.slots_true, frozen=True)
2979
+ class Discriminator:
2980
+ """!!! abstract "Usage Documentation"
2981
+ [Discriminated Unions with `Callable` `Discriminator`](../concepts/unions.md#discriminated-unions-with-callable-discriminator)
2982
+
2983
+ Provides a way to use a custom callable as the way to extract the value of a union discriminator.
2984
+
2985
+ This allows you to get validation behavior like you'd get from `Field(discriminator=<field_name>)`,
2986
+ but without needing to have a single shared field across all the union choices. This also makes it
2987
+ possible to handle unions of models and primitive types with discriminated-union-style validation errors.
2988
+ Finally, this allows you to use a custom callable as the way to identify which member of a union a value
2989
+ belongs to, while still seeing all the performance benefits of a discriminated union.
2990
+
2991
+ Consider this example, which is much more performant with the use of `Discriminator` and thus a `TaggedUnion`
2992
+ than it would be as a normal `Union`.
2993
+
2994
+ ```python
2995
+ from typing import Annotated, Any, Literal, Union
2996
+
2997
+ from pydantic import BaseModel, Discriminator, Tag
2998
+
2999
+ class Pie(BaseModel):
3000
+ time_to_cook: int
3001
+ num_ingredients: int
3002
+
3003
+ class ApplePie(Pie):
3004
+ fruit: Literal['apple'] = 'apple'
3005
+
3006
+ class PumpkinPie(Pie):
3007
+ filling: Literal['pumpkin'] = 'pumpkin'
3008
+
3009
+ def get_discriminator_value(v: Any) -> str:
3010
+ if isinstance(v, dict):
3011
+ return v.get('fruit', v.get('filling'))
3012
+ return getattr(v, 'fruit', getattr(v, 'filling', None))
3013
+
3014
+ class ThanksgivingDinner(BaseModel):
3015
+ dessert: Annotated[
3016
+ Union[
3017
+ Annotated[ApplePie, Tag('apple')],
3018
+ Annotated[PumpkinPie, Tag('pumpkin')],
3019
+ ],
3020
+ Discriminator(get_discriminator_value),
3021
+ ]
3022
+
3023
+ apple_variation = ThanksgivingDinner.model_validate(
3024
+ {'dessert': {'fruit': 'apple', 'time_to_cook': 60, 'num_ingredients': 8}}
3025
+ )
3026
+ print(repr(apple_variation))
3027
+ '''
3028
+ ThanksgivingDinner(dessert=ApplePie(time_to_cook=60, num_ingredients=8, fruit='apple'))
3029
+ '''
3030
+
3031
+ pumpkin_variation = ThanksgivingDinner.model_validate(
3032
+ {
3033
+ 'dessert': {
3034
+ 'filling': 'pumpkin',
3035
+ 'time_to_cook': 40,
3036
+ 'num_ingredients': 6,
3037
+ }
3038
+ }
3039
+ )
3040
+ print(repr(pumpkin_variation))
3041
+ '''
3042
+ ThanksgivingDinner(dessert=PumpkinPie(time_to_cook=40, num_ingredients=6, filling='pumpkin'))
3043
+ '''
3044
+ ```
3045
+
3046
+ See the [Discriminated Unions] concepts docs for more details on how to use `Discriminator`s.
3047
+
3048
+ [Discriminated Unions]: ../concepts/unions.md#discriminated-unions
3049
+ """
3050
+
3051
+ discriminator: str | Callable[[Any], Hashable]
3052
+ """The callable or field name for discriminating the type in a tagged union.
3053
+
3054
+ A `Callable` discriminator must extract the value of the discriminator from the input.
3055
+ A `str` discriminator must be the name of a field to discriminate against.
3056
+ """
3057
+ custom_error_type: str | None = None
3058
+ """Type to use in [custom errors](../errors/errors.md) replacing the standard discriminated union
3059
+ validation errors.
3060
+ """
3061
+ custom_error_message: str | None = None
3062
+ """Message to use in custom errors."""
3063
+ custom_error_context: dict[str, int | str | float] | None = None
3064
+ """Context to use in custom errors."""
3065
+
3066
+ def __get_pydantic_core_schema__(self, source_type: Any, handler: GetCoreSchemaHandler) -> CoreSchema:
3067
+ if isinstance(self.discriminator, str):
3068
+ from pydantic import Field
3069
+
3070
+ return handler(Annotated[source_type, Field(discriminator=self.discriminator)])
3071
+ else:
3072
+ original_schema = handler(source_type)
3073
+ return self._convert_schema(original_schema, handler)
3074
+
3075
+ def _convert_schema(
3076
+ self, original_schema: core_schema.CoreSchema, handler: GetCoreSchemaHandler | None = None
3077
+ ) -> core_schema.TaggedUnionSchema:
3078
+ if handler is not None and original_schema['type'] == 'definition-ref':
3079
+ # Same logic as `_ApplyInferredDiscriminator._apply_to_root()`
3080
+ try:
3081
+ def_schema = handler.resolve_ref_schema(original_schema)
3082
+ except LookupError: # pragma: no cover
3083
+ from pydantic._internal._discriminated_union import MissingDefinitionForUnionRef
3084
+
3085
+ raise MissingDefinitionForUnionRef(original_schema['schema_ref'])
3086
+
3087
+ # If using a referenceable union as discriminated (e.g. `type Pet = Cat | Dog; field: Pet = Field(discriminator=...)`):
3088
+ if def_schema['type'] == 'union':
3089
+ original_schema = def_schema.copy()
3090
+ original_schema.pop('ref')
3091
+
3092
+ if original_schema['type'] != 'union':
3093
+ # This likely indicates that the schema was a single-item union that was simplified.
3094
+ # In this case, we do the same thing we do in
3095
+ # `pydantic._internal._discriminated_union._ApplyInferredDiscriminator._apply_to_root`, namely,
3096
+ # package the generated schema back into a single-item union.
3097
+ original_schema = core_schema.union_schema([original_schema])
3098
+
3099
+ tagged_union_choices = {}
3100
+ for choice in original_schema['choices']:
3101
+ tag = None
3102
+ if isinstance(choice, tuple):
3103
+ choice, tag = choice
3104
+ metadata = cast('CoreMetadata | None', choice.get('metadata'))
3105
+ if metadata is not None:
3106
+ tag = metadata.get('pydantic_internal_union_tag_key') or tag
3107
+ if tag is None:
3108
+ # `handler` is None when this method is called from `apply_discriminator()` (deferred discriminators)
3109
+ if handler is not None and choice['type'] == 'definition-ref':
3110
+ # If choice was built from a PEP 695 type alias, try to resolve the def:
3111
+ try:
3112
+ choice = handler.resolve_ref_schema(choice)
3113
+ except LookupError:
3114
+ pass
3115
+ else:
3116
+ metadata = cast('CoreMetadata | None', choice.get('metadata'))
3117
+ if metadata is not None:
3118
+ tag = metadata.get('pydantic_internal_union_tag_key')
3119
+
3120
+ if tag is None:
3121
+ raise PydanticUserError(
3122
+ f'`Tag` not provided for choice {choice} used with `Discriminator`',
3123
+ code='callable-discriminator-no-tag',
3124
+ )
3125
+ tagged_union_choices[tag] = choice
3126
+
3127
+ # Have to do these verbose checks to ensure falsy values ('' and {}) don't get ignored
3128
+ custom_error_type = self.custom_error_type
3129
+ if custom_error_type is None:
3130
+ custom_error_type = original_schema.get('custom_error_type')
3131
+
3132
+ custom_error_message = self.custom_error_message
3133
+ if custom_error_message is None:
3134
+ custom_error_message = original_schema.get('custom_error_message')
3135
+
3136
+ custom_error_context = self.custom_error_context
3137
+ if custom_error_context is None:
3138
+ custom_error_context = original_schema.get('custom_error_context')
3139
+
3140
+ custom_error_type = original_schema.get('custom_error_type') if custom_error_type is None else custom_error_type
3141
+ return core_schema.tagged_union_schema(
3142
+ tagged_union_choices,
3143
+ self.discriminator,
3144
+ custom_error_type=custom_error_type,
3145
+ custom_error_message=custom_error_message,
3146
+ custom_error_context=custom_error_context,
3147
+ strict=original_schema.get('strict'),
3148
+ ref=original_schema.get('ref'),
3149
+ metadata=original_schema.get('metadata'),
3150
+ serialization=original_schema.get('serialization'),
3151
+ )
3152
+
3153
+
3154
+ _JSON_TYPES = {int, float, str, bool, list, dict, type(None)}
3155
+
3156
+
3157
+ def _get_type_name(x: Any) -> str:
3158
+ type_ = type(x)
3159
+ if type_ in _JSON_TYPES:
3160
+ return type_.__name__
3161
+
3162
+ # Handle proper subclasses; note we don't need to handle None or bool here
3163
+ if isinstance(x, int):
3164
+ return 'int'
3165
+ if isinstance(x, float):
3166
+ return 'float'
3167
+ if isinstance(x, str):
3168
+ return 'str'
3169
+ if isinstance(x, list):
3170
+ return 'list'
3171
+ if isinstance(x, dict):
3172
+ return 'dict'
3173
+
3174
+ # Fail by returning the type's actual name
3175
+ return getattr(type_, '__name__', '<no type name>')
3176
+
3177
+
3178
+ class _AllowAnyJson:
3179
+ @classmethod
3180
+ def __get_pydantic_core_schema__(cls, source_type: Any, handler: GetCoreSchemaHandler) -> CoreSchema:
3181
+ python_schema = handler(source_type)
3182
+ return core_schema.json_or_python_schema(json_schema=core_schema.any_schema(), python_schema=python_schema)
3183
+
3184
+
3185
+ if TYPE_CHECKING:
3186
+ # This seems to only be necessary for mypy
3187
+ JsonValue: TypeAlias = Union[
3188
+ list['JsonValue'],
3189
+ dict[str, 'JsonValue'],
3190
+ str,
3191
+ bool,
3192
+ int,
3193
+ float,
3194
+ None,
3195
+ ]
3196
+ """A `JsonValue` is used to represent a value that can be serialized to JSON.
3197
+
3198
+ It may be one of:
3199
+
3200
+ * `list['JsonValue']`
3201
+ * `dict[str, 'JsonValue']`
3202
+ * `str`
3203
+ * `bool`
3204
+ * `int`
3205
+ * `float`
3206
+ * `None`
3207
+
3208
+ The following example demonstrates how to use `JsonValue` to validate JSON data,
3209
+ and what kind of errors to expect when input data is not json serializable.
3210
+
3211
+ ```python
3212
+ import json
3213
+
3214
+ from pydantic import BaseModel, JsonValue, ValidationError
3215
+
3216
+ class Model(BaseModel):
3217
+ j: JsonValue
3218
+
3219
+ valid_json_data = {'j': {'a': {'b': {'c': 1, 'd': [2, None]}}}}
3220
+ invalid_json_data = {'j': {'a': {'b': ...}}}
3221
+
3222
+ print(repr(Model.model_validate(valid_json_data)))
3223
+ #> Model(j={'a': {'b': {'c': 1, 'd': [2, None]}}})
3224
+ print(repr(Model.model_validate_json(json.dumps(valid_json_data))))
3225
+ #> Model(j={'a': {'b': {'c': 1, 'd': [2, None]}}})
3226
+
3227
+ try:
3228
+ Model.model_validate(invalid_json_data)
3229
+ except ValidationError as e:
3230
+ print(e)
3231
+ '''
3232
+ 1 validation error for Model
3233
+ j.dict.a.dict.b
3234
+ input was not a valid JSON value [type=invalid-json-value, input_value=Ellipsis, input_type=ellipsis]
3235
+ '''
3236
+ ```
3237
+ """
3238
+
3239
+ else:
3240
+ JsonValue = TypeAliasType(
3241
+ 'JsonValue',
3242
+ Annotated[
3243
+ Union[
3244
+ Annotated[list['JsonValue'], Tag('list')],
3245
+ Annotated[dict[str, 'JsonValue'], Tag('dict')],
3246
+ Annotated[str, Tag('str')],
3247
+ Annotated[bool, Tag('bool')],
3248
+ Annotated[int, Tag('int')],
3249
+ Annotated[float, Tag('float')],
3250
+ Annotated[None, Tag('NoneType')],
3251
+ ],
3252
+ Discriminator(
3253
+ _get_type_name,
3254
+ custom_error_type='invalid-json-value',
3255
+ custom_error_message='input was not a valid JSON value',
3256
+ ),
3257
+ _AllowAnyJson,
3258
+ ],
3259
+ )
3260
+
3261
+
3262
+ class _OnErrorOmit:
3263
+ @classmethod
3264
+ def __get_pydantic_core_schema__(cls, source_type: Any, handler: GetCoreSchemaHandler) -> CoreSchema:
3265
+ # there is no actual default value here but we use with_default_schema since it already has the on_error
3266
+ # behavior implemented and it would be no more efficient to implement it on every other validator
3267
+ # or as a standalone validator
3268
+ return core_schema.with_default_schema(schema=handler(source_type), on_error='omit')
3269
+
3270
+
3271
+ OnErrorOmit = Annotated[T, _OnErrorOmit]
3272
+ """
3273
+ When used as an item in a list, the key type in a dict, optional values of a TypedDict, etc.
3274
+ this annotation omits the item from the iteration if there is any error validating it.
3275
+ That is, instead of a [`ValidationError`][pydantic_core.ValidationError] being propagated up and the entire iterable being discarded
3276
+ any invalid items are discarded and the valid ones are returned.
3277
+ """
3278
+
3279
+
3280
+ @_dataclasses.dataclass
3281
+ class FailFast(_fields.PydanticMetadata, BaseMetadata):
3282
+ """A `FailFast` annotation can be used to specify that validation should stop at the first error.
3283
+
3284
+ This can be useful when you want to validate a large amount of data and you only need to know if it's valid or not.
3285
+
3286
+ You might want to enable this setting if you want to validate your data faster (basically, if you use this,
3287
+ validation will be more performant with the caveat that you get less information).
3288
+
3289
+ ```python
3290
+ from typing import Annotated
3291
+
3292
+ from pydantic import BaseModel, FailFast, ValidationError
3293
+
3294
+ class Model(BaseModel):
3295
+ x: Annotated[list[int], FailFast()]
3296
+
3297
+ # This will raise a single error for the first invalid value and stop validation
3298
+ try:
3299
+ obj = Model(x=[1, 2, 'a', 4, 5, 'b', 7, 8, 9, 'c'])
3300
+ except ValidationError as e:
3301
+ print(e)
3302
+ '''
3303
+ 1 validation error for Model
3304
+ x.2
3305
+ Input should be a valid integer, unable to parse string as an integer [type=int_parsing, input_value='a', input_type=str]
3306
+ '''
3307
+ ```
3308
+ """
3309
+
3310
+ fail_fast: bool = True