coinex-api 0.0.15__py3-none-any.whl → 0.0.16__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 (289) hide show
  1. coinex/__init__.py +7 -0
  2. coinex/ccxt/__init__.py +101 -0
  3. coinex/ccxt/abstract/coinex.py +237 -0
  4. coinex/ccxt/async_support/__init__.py +80 -0
  5. coinex/ccxt/async_support/base/__init__.py +1 -0
  6. coinex/ccxt/async_support/base/exchange.py +2100 -0
  7. coinex/ccxt/async_support/base/throttler.py +50 -0
  8. coinex/ccxt/async_support/base/ws/__init__.py +38 -0
  9. coinex/ccxt/async_support/base/ws/aiohttp_client.py +147 -0
  10. coinex/ccxt/async_support/base/ws/cache.py +213 -0
  11. coinex/ccxt/async_support/base/ws/client.py +214 -0
  12. coinex/ccxt/async_support/base/ws/fast_client.py +97 -0
  13. coinex/ccxt/async_support/base/ws/functions.py +59 -0
  14. coinex/ccxt/async_support/base/ws/future.py +69 -0
  15. coinex/ccxt/async_support/base/ws/order_book.py +78 -0
  16. coinex/ccxt/async_support/base/ws/order_book_side.py +174 -0
  17. coinex/ccxt/async_support/coinex.py +5833 -0
  18. coinex/ccxt/base/__init__.py +27 -0
  19. coinex/ccxt/base/decimal_to_precision.py +174 -0
  20. coinex/ccxt/base/errors.py +267 -0
  21. coinex/ccxt/base/exchange.py +6769 -0
  22. coinex/ccxt/base/precise.py +297 -0
  23. coinex/ccxt/base/types.py +577 -0
  24. coinex/ccxt/coinex.py +5832 -0
  25. coinex/ccxt/pro/__init__.py +21 -0
  26. coinex/ccxt/pro/coinex.py +1366 -0
  27. coinex/ccxt/static_dependencies/README.md +1 -0
  28. coinex/ccxt/static_dependencies/__init__.py +1 -0
  29. coinex/ccxt/static_dependencies/ecdsa/__init__.py +14 -0
  30. coinex/ccxt/static_dependencies/ecdsa/_version.py +520 -0
  31. coinex/ccxt/static_dependencies/ecdsa/curves.py +56 -0
  32. coinex/ccxt/static_dependencies/ecdsa/der.py +221 -0
  33. coinex/ccxt/static_dependencies/ecdsa/ecdsa.py +310 -0
  34. coinex/ccxt/static_dependencies/ecdsa/ellipticcurve.py +197 -0
  35. coinex/ccxt/static_dependencies/ecdsa/keys.py +332 -0
  36. coinex/ccxt/static_dependencies/ecdsa/numbertheory.py +531 -0
  37. coinex/ccxt/static_dependencies/ecdsa/rfc6979.py +100 -0
  38. coinex/ccxt/static_dependencies/ecdsa/util.py +266 -0
  39. coinex/ccxt/static_dependencies/ethereum/__init__.py +7 -0
  40. coinex/ccxt/static_dependencies/ethereum/abi/__init__.py +16 -0
  41. coinex/ccxt/static_dependencies/ethereum/abi/abi.py +19 -0
  42. coinex/ccxt/static_dependencies/ethereum/abi/base.py +152 -0
  43. coinex/ccxt/static_dependencies/ethereum/abi/codec.py +217 -0
  44. coinex/ccxt/static_dependencies/ethereum/abi/constants.py +3 -0
  45. coinex/ccxt/static_dependencies/ethereum/abi/decoding.py +565 -0
  46. coinex/ccxt/static_dependencies/ethereum/abi/encoding.py +720 -0
  47. coinex/ccxt/static_dependencies/ethereum/abi/exceptions.py +139 -0
  48. coinex/ccxt/static_dependencies/ethereum/abi/grammar.py +443 -0
  49. coinex/ccxt/static_dependencies/ethereum/abi/packed.py +13 -0
  50. coinex/ccxt/static_dependencies/ethereum/abi/py.typed +0 -0
  51. coinex/ccxt/static_dependencies/ethereum/abi/registry.py +643 -0
  52. coinex/ccxt/static_dependencies/ethereum/abi/tools/__init__.py +3 -0
  53. coinex/ccxt/static_dependencies/ethereum/abi/tools/_strategies.py +230 -0
  54. coinex/ccxt/static_dependencies/ethereum/abi/utils/__init__.py +0 -0
  55. coinex/ccxt/static_dependencies/ethereum/abi/utils/numeric.py +83 -0
  56. coinex/ccxt/static_dependencies/ethereum/abi/utils/padding.py +27 -0
  57. coinex/ccxt/static_dependencies/ethereum/abi/utils/string.py +19 -0
  58. coinex/ccxt/static_dependencies/ethereum/account/__init__.py +3 -0
  59. coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/__init__.py +4 -0
  60. coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/encoding_and_hashing.py +239 -0
  61. coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/helpers.py +40 -0
  62. coinex/ccxt/static_dependencies/ethereum/account/messages.py +263 -0
  63. coinex/ccxt/static_dependencies/ethereum/account/py.typed +0 -0
  64. coinex/ccxt/static_dependencies/ethereum/hexbytes/__init__.py +5 -0
  65. coinex/ccxt/static_dependencies/ethereum/hexbytes/_utils.py +54 -0
  66. coinex/ccxt/static_dependencies/ethereum/hexbytes/main.py +65 -0
  67. coinex/ccxt/static_dependencies/ethereum/hexbytes/py.typed +0 -0
  68. coinex/ccxt/static_dependencies/ethereum/typing/__init__.py +63 -0
  69. coinex/ccxt/static_dependencies/ethereum/typing/abi.py +6 -0
  70. coinex/ccxt/static_dependencies/ethereum/typing/bls.py +7 -0
  71. coinex/ccxt/static_dependencies/ethereum/typing/discovery.py +5 -0
  72. coinex/ccxt/static_dependencies/ethereum/typing/encoding.py +7 -0
  73. coinex/ccxt/static_dependencies/ethereum/typing/enums.py +17 -0
  74. coinex/ccxt/static_dependencies/ethereum/typing/ethpm.py +9 -0
  75. coinex/ccxt/static_dependencies/ethereum/typing/evm.py +20 -0
  76. coinex/ccxt/static_dependencies/ethereum/typing/networks.py +1122 -0
  77. coinex/ccxt/static_dependencies/ethereum/typing/py.typed +0 -0
  78. coinex/ccxt/static_dependencies/ethereum/utils/__init__.py +115 -0
  79. coinex/ccxt/static_dependencies/ethereum/utils/abi.py +72 -0
  80. coinex/ccxt/static_dependencies/ethereum/utils/address.py +171 -0
  81. coinex/ccxt/static_dependencies/ethereum/utils/applicators.py +151 -0
  82. coinex/ccxt/static_dependencies/ethereum/utils/conversions.py +190 -0
  83. coinex/ccxt/static_dependencies/ethereum/utils/currency.py +107 -0
  84. coinex/ccxt/static_dependencies/ethereum/utils/curried/__init__.py +269 -0
  85. coinex/ccxt/static_dependencies/ethereum/utils/debug.py +20 -0
  86. coinex/ccxt/static_dependencies/ethereum/utils/decorators.py +132 -0
  87. coinex/ccxt/static_dependencies/ethereum/utils/encoding.py +6 -0
  88. coinex/ccxt/static_dependencies/ethereum/utils/exceptions.py +4 -0
  89. coinex/ccxt/static_dependencies/ethereum/utils/functional.py +75 -0
  90. coinex/ccxt/static_dependencies/ethereum/utils/hexadecimal.py +74 -0
  91. coinex/ccxt/static_dependencies/ethereum/utils/humanize.py +188 -0
  92. coinex/ccxt/static_dependencies/ethereum/utils/logging.py +159 -0
  93. coinex/ccxt/static_dependencies/ethereum/utils/module_loading.py +31 -0
  94. coinex/ccxt/static_dependencies/ethereum/utils/numeric.py +43 -0
  95. coinex/ccxt/static_dependencies/ethereum/utils/py.typed +0 -0
  96. coinex/ccxt/static_dependencies/ethereum/utils/toolz.py +76 -0
  97. coinex/ccxt/static_dependencies/ethereum/utils/types.py +54 -0
  98. coinex/ccxt/static_dependencies/ethereum/utils/typing/__init__.py +18 -0
  99. coinex/ccxt/static_dependencies/ethereum/utils/typing/misc.py +14 -0
  100. coinex/ccxt/static_dependencies/ethereum/utils/units.py +31 -0
  101. coinex/ccxt/static_dependencies/keccak/__init__.py +3 -0
  102. coinex/ccxt/static_dependencies/keccak/keccak.py +197 -0
  103. coinex/ccxt/static_dependencies/lark/__init__.py +38 -0
  104. coinex/ccxt/static_dependencies/lark/__pyinstaller/__init__.py +6 -0
  105. coinex/ccxt/static_dependencies/lark/__pyinstaller/hook-lark.py +14 -0
  106. coinex/ccxt/static_dependencies/lark/ast_utils.py +59 -0
  107. coinex/ccxt/static_dependencies/lark/common.py +86 -0
  108. coinex/ccxt/static_dependencies/lark/exceptions.py +292 -0
  109. coinex/ccxt/static_dependencies/lark/grammar.py +130 -0
  110. coinex/ccxt/static_dependencies/lark/grammars/__init__.py +0 -0
  111. coinex/ccxt/static_dependencies/lark/grammars/common.lark +59 -0
  112. coinex/ccxt/static_dependencies/lark/grammars/lark.lark +62 -0
  113. coinex/ccxt/static_dependencies/lark/grammars/python.lark +302 -0
  114. coinex/ccxt/static_dependencies/lark/grammars/unicode.lark +7 -0
  115. coinex/ccxt/static_dependencies/lark/indenter.py +143 -0
  116. coinex/ccxt/static_dependencies/lark/lark.py +658 -0
  117. coinex/ccxt/static_dependencies/lark/lexer.py +678 -0
  118. coinex/ccxt/static_dependencies/lark/load_grammar.py +1428 -0
  119. coinex/ccxt/static_dependencies/lark/parse_tree_builder.py +391 -0
  120. coinex/ccxt/static_dependencies/lark/parser_frontends.py +257 -0
  121. coinex/ccxt/static_dependencies/lark/parsers/__init__.py +0 -0
  122. coinex/ccxt/static_dependencies/lark/parsers/cyk.py +340 -0
  123. coinex/ccxt/static_dependencies/lark/parsers/earley.py +314 -0
  124. coinex/ccxt/static_dependencies/lark/parsers/earley_common.py +42 -0
  125. coinex/ccxt/static_dependencies/lark/parsers/earley_forest.py +801 -0
  126. coinex/ccxt/static_dependencies/lark/parsers/grammar_analysis.py +203 -0
  127. coinex/ccxt/static_dependencies/lark/parsers/lalr_analysis.py +332 -0
  128. coinex/ccxt/static_dependencies/lark/parsers/lalr_interactive_parser.py +158 -0
  129. coinex/ccxt/static_dependencies/lark/parsers/lalr_parser.py +122 -0
  130. coinex/ccxt/static_dependencies/lark/parsers/lalr_parser_state.py +110 -0
  131. coinex/ccxt/static_dependencies/lark/parsers/xearley.py +165 -0
  132. coinex/ccxt/static_dependencies/lark/py.typed +0 -0
  133. coinex/ccxt/static_dependencies/lark/reconstruct.py +107 -0
  134. coinex/ccxt/static_dependencies/lark/tools/__init__.py +70 -0
  135. coinex/ccxt/static_dependencies/lark/tools/nearley.py +202 -0
  136. coinex/ccxt/static_dependencies/lark/tools/serialize.py +32 -0
  137. coinex/ccxt/static_dependencies/lark/tools/standalone.py +196 -0
  138. coinex/ccxt/static_dependencies/lark/tree.py +267 -0
  139. coinex/ccxt/static_dependencies/lark/tree_matcher.py +186 -0
  140. coinex/ccxt/static_dependencies/lark/tree_templates.py +180 -0
  141. coinex/ccxt/static_dependencies/lark/utils.py +343 -0
  142. coinex/ccxt/static_dependencies/lark/visitors.py +596 -0
  143. coinex/ccxt/static_dependencies/marshmallow/__init__.py +81 -0
  144. coinex/ccxt/static_dependencies/marshmallow/base.py +65 -0
  145. coinex/ccxt/static_dependencies/marshmallow/class_registry.py +94 -0
  146. coinex/ccxt/static_dependencies/marshmallow/decorators.py +231 -0
  147. coinex/ccxt/static_dependencies/marshmallow/error_store.py +60 -0
  148. coinex/ccxt/static_dependencies/marshmallow/exceptions.py +71 -0
  149. coinex/ccxt/static_dependencies/marshmallow/fields.py +2114 -0
  150. coinex/ccxt/static_dependencies/marshmallow/orderedset.py +89 -0
  151. coinex/ccxt/static_dependencies/marshmallow/py.typed +0 -0
  152. coinex/ccxt/static_dependencies/marshmallow/schema.py +1228 -0
  153. coinex/ccxt/static_dependencies/marshmallow/types.py +12 -0
  154. coinex/ccxt/static_dependencies/marshmallow/utils.py +378 -0
  155. coinex/ccxt/static_dependencies/marshmallow/validate.py +678 -0
  156. coinex/ccxt/static_dependencies/marshmallow/warnings.py +2 -0
  157. coinex/ccxt/static_dependencies/marshmallow_dataclass/__init__.py +1047 -0
  158. coinex/ccxt/static_dependencies/marshmallow_dataclass/collection_field.py +51 -0
  159. coinex/ccxt/static_dependencies/marshmallow_dataclass/lazy_class_attribute.py +45 -0
  160. coinex/ccxt/static_dependencies/marshmallow_dataclass/mypy.py +71 -0
  161. coinex/ccxt/static_dependencies/marshmallow_dataclass/py.typed +0 -0
  162. coinex/ccxt/static_dependencies/marshmallow_dataclass/typing.py +14 -0
  163. coinex/ccxt/static_dependencies/marshmallow_dataclass/union_field.py +82 -0
  164. coinex/ccxt/static_dependencies/marshmallow_oneofschema/__init__.py +1 -0
  165. coinex/ccxt/static_dependencies/marshmallow_oneofschema/one_of_schema.py +193 -0
  166. coinex/ccxt/static_dependencies/marshmallow_oneofschema/py.typed +0 -0
  167. coinex/ccxt/static_dependencies/msgpack/__init__.py +55 -0
  168. coinex/ccxt/static_dependencies/msgpack/_cmsgpack.pyx +11 -0
  169. coinex/ccxt/static_dependencies/msgpack/_packer.pyx +374 -0
  170. coinex/ccxt/static_dependencies/msgpack/_unpacker.pyx +547 -0
  171. coinex/ccxt/static_dependencies/msgpack/buff_converter.h +8 -0
  172. coinex/ccxt/static_dependencies/msgpack/exceptions.py +48 -0
  173. coinex/ccxt/static_dependencies/msgpack/ext.py +168 -0
  174. coinex/ccxt/static_dependencies/msgpack/fallback.py +951 -0
  175. coinex/ccxt/static_dependencies/msgpack/pack.h +89 -0
  176. coinex/ccxt/static_dependencies/msgpack/pack_template.h +820 -0
  177. coinex/ccxt/static_dependencies/msgpack/sysdep.h +194 -0
  178. coinex/ccxt/static_dependencies/msgpack/unpack.h +391 -0
  179. coinex/ccxt/static_dependencies/msgpack/unpack_define.h +95 -0
  180. coinex/ccxt/static_dependencies/msgpack/unpack_template.h +464 -0
  181. coinex/ccxt/static_dependencies/parsimonious/__init__.py +10 -0
  182. coinex/ccxt/static_dependencies/parsimonious/exceptions.py +105 -0
  183. coinex/ccxt/static_dependencies/parsimonious/expressions.py +479 -0
  184. coinex/ccxt/static_dependencies/parsimonious/grammar.py +487 -0
  185. coinex/ccxt/static_dependencies/parsimonious/nodes.py +325 -0
  186. coinex/ccxt/static_dependencies/parsimonious/utils.py +40 -0
  187. coinex/ccxt/static_dependencies/starknet/__init__.py +0 -0
  188. coinex/ccxt/static_dependencies/starknet/abi/v0/__init__.py +2 -0
  189. coinex/ccxt/static_dependencies/starknet/abi/v0/model.py +44 -0
  190. coinex/ccxt/static_dependencies/starknet/abi/v0/parser.py +216 -0
  191. coinex/ccxt/static_dependencies/starknet/abi/v0/schemas.py +72 -0
  192. coinex/ccxt/static_dependencies/starknet/abi/v0/shape.py +63 -0
  193. coinex/ccxt/static_dependencies/starknet/abi/v1/__init__.py +2 -0
  194. coinex/ccxt/static_dependencies/starknet/abi/v1/core_structures.json +14 -0
  195. coinex/ccxt/static_dependencies/starknet/abi/v1/model.py +39 -0
  196. coinex/ccxt/static_dependencies/starknet/abi/v1/parser.py +220 -0
  197. coinex/ccxt/static_dependencies/starknet/abi/v1/parser_transformer.py +179 -0
  198. coinex/ccxt/static_dependencies/starknet/abi/v1/schemas.py +66 -0
  199. coinex/ccxt/static_dependencies/starknet/abi/v1/shape.py +47 -0
  200. coinex/ccxt/static_dependencies/starknet/abi/v2/__init__.py +2 -0
  201. coinex/ccxt/static_dependencies/starknet/abi/v2/model.py +89 -0
  202. coinex/ccxt/static_dependencies/starknet/abi/v2/parser.py +293 -0
  203. coinex/ccxt/static_dependencies/starknet/abi/v2/parser_transformer.py +192 -0
  204. coinex/ccxt/static_dependencies/starknet/abi/v2/schemas.py +132 -0
  205. coinex/ccxt/static_dependencies/starknet/abi/v2/shape.py +107 -0
  206. coinex/ccxt/static_dependencies/starknet/cairo/__init__.py +0 -0
  207. coinex/ccxt/static_dependencies/starknet/cairo/data_types.py +123 -0
  208. coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/__init__.py +0 -0
  209. coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/cairo_types.py +77 -0
  210. coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser.py +46 -0
  211. coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser_transformer.py +138 -0
  212. coinex/ccxt/static_dependencies/starknet/cairo/felt.py +64 -0
  213. coinex/ccxt/static_dependencies/starknet/cairo/type_parser.py +121 -0
  214. coinex/ccxt/static_dependencies/starknet/cairo/v1/__init__.py +0 -0
  215. coinex/ccxt/static_dependencies/starknet/cairo/v1/type_parser.py +59 -0
  216. coinex/ccxt/static_dependencies/starknet/cairo/v2/__init__.py +0 -0
  217. coinex/ccxt/static_dependencies/starknet/cairo/v2/type_parser.py +77 -0
  218. coinex/ccxt/static_dependencies/starknet/ccxt_utils.py +7 -0
  219. coinex/ccxt/static_dependencies/starknet/common.py +15 -0
  220. coinex/ccxt/static_dependencies/starknet/constants.py +39 -0
  221. coinex/ccxt/static_dependencies/starknet/hash/__init__.py +0 -0
  222. coinex/ccxt/static_dependencies/starknet/hash/address.py +79 -0
  223. coinex/ccxt/static_dependencies/starknet/hash/compiled_class_hash_objects.py +111 -0
  224. coinex/ccxt/static_dependencies/starknet/hash/selector.py +16 -0
  225. coinex/ccxt/static_dependencies/starknet/hash/storage.py +12 -0
  226. coinex/ccxt/static_dependencies/starknet/hash/utils.py +78 -0
  227. coinex/ccxt/static_dependencies/starknet/models/__init__.py +0 -0
  228. coinex/ccxt/static_dependencies/starknet/models/typed_data.py +45 -0
  229. coinex/ccxt/static_dependencies/starknet/serialization/__init__.py +24 -0
  230. coinex/ccxt/static_dependencies/starknet/serialization/_calldata_reader.py +40 -0
  231. coinex/ccxt/static_dependencies/starknet/serialization/_context.py +142 -0
  232. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/__init__.py +10 -0
  233. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/_common.py +82 -0
  234. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/array_serializer.py +43 -0
  235. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/bool_serializer.py +37 -0
  236. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/byte_array_serializer.py +66 -0
  237. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/cairo_data_serializer.py +71 -0
  238. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/enum_serializer.py +71 -0
  239. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/felt_serializer.py +50 -0
  240. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/named_tuple_serializer.py +58 -0
  241. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/option_serializer.py +43 -0
  242. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/output_serializer.py +40 -0
  243. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/payload_serializer.py +72 -0
  244. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/struct_serializer.py +36 -0
  245. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/tuple_serializer.py +36 -0
  246. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/uint256_serializer.py +76 -0
  247. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/uint_serializer.py +100 -0
  248. coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/unit_serializer.py +32 -0
  249. coinex/ccxt/static_dependencies/starknet/serialization/errors.py +10 -0
  250. coinex/ccxt/static_dependencies/starknet/serialization/factory.py +229 -0
  251. coinex/ccxt/static_dependencies/starknet/serialization/function_serialization_adapter.py +110 -0
  252. coinex/ccxt/static_dependencies/starknet/serialization/tuple_dataclass.py +59 -0
  253. coinex/ccxt/static_dependencies/starknet/utils/__init__.py +0 -0
  254. coinex/ccxt/static_dependencies/starknet/utils/constructor_args_translator.py +86 -0
  255. coinex/ccxt/static_dependencies/starknet/utils/iterable.py +13 -0
  256. coinex/ccxt/static_dependencies/starknet/utils/schema.py +13 -0
  257. coinex/ccxt/static_dependencies/starknet/utils/typed_data.py +182 -0
  258. coinex/ccxt/static_dependencies/starkware/__init__.py +0 -0
  259. coinex/ccxt/static_dependencies/starkware/crypto/__init__.py +0 -0
  260. coinex/ccxt/static_dependencies/starkware/crypto/fast_pedersen_hash.py +50 -0
  261. coinex/ccxt/static_dependencies/starkware/crypto/math_utils.py +78 -0
  262. coinex/ccxt/static_dependencies/starkware/crypto/signature.py +2344 -0
  263. coinex/ccxt/static_dependencies/starkware/crypto/utils.py +63 -0
  264. coinex/ccxt/static_dependencies/sympy/__init__.py +0 -0
  265. coinex/ccxt/static_dependencies/sympy/core/__init__.py +0 -0
  266. coinex/ccxt/static_dependencies/sympy/core/intfunc.py +35 -0
  267. coinex/ccxt/static_dependencies/sympy/external/__init__.py +0 -0
  268. coinex/ccxt/static_dependencies/sympy/external/gmpy.py +345 -0
  269. coinex/ccxt/static_dependencies/sympy/external/importtools.py +187 -0
  270. coinex/ccxt/static_dependencies/sympy/external/ntheory.py +637 -0
  271. coinex/ccxt/static_dependencies/sympy/external/pythonmpq.py +341 -0
  272. coinex/ccxt/static_dependencies/toolz/__init__.py +26 -0
  273. coinex/ccxt/static_dependencies/toolz/_signatures.py +784 -0
  274. coinex/ccxt/static_dependencies/toolz/_version.py +520 -0
  275. coinex/ccxt/static_dependencies/toolz/compatibility.py +30 -0
  276. coinex/ccxt/static_dependencies/toolz/curried/__init__.py +101 -0
  277. coinex/ccxt/static_dependencies/toolz/curried/exceptions.py +22 -0
  278. coinex/ccxt/static_dependencies/toolz/curried/operator.py +22 -0
  279. coinex/ccxt/static_dependencies/toolz/dicttoolz.py +339 -0
  280. coinex/ccxt/static_dependencies/toolz/functoolz.py +1049 -0
  281. coinex/ccxt/static_dependencies/toolz/itertoolz.py +1057 -0
  282. coinex/ccxt/static_dependencies/toolz/recipes.py +46 -0
  283. coinex/ccxt/static_dependencies/toolz/utils.py +9 -0
  284. coinex/ccxt/static_dependencies/typing_inspect/__init__.py +0 -0
  285. coinex/ccxt/static_dependencies/typing_inspect/typing_inspect.py +851 -0
  286. {coinex_api-0.0.15.dist-info → coinex_api-0.0.16.dist-info}/METADATA +1 -1
  287. coinex_api-0.0.16.dist-info/RECORD +288 -0
  288. coinex_api-0.0.15.dist-info/RECORD +0 -3
  289. {coinex_api-0.0.15.dist-info → coinex_api-0.0.16.dist-info}/WHEEL +0 -0
@@ -0,0 +1,531 @@
1
+ #! /usr/bin/env python
2
+ #
3
+ # Provide some simple capabilities from number theory.
4
+ #
5
+ # Version of 2008.11.14.
6
+ #
7
+ # Written in 2005 and 2006 by Peter Pearson and placed in the public domain.
8
+ # Revision history:
9
+ # 2008.11.14: Use pow(base, exponent, modulus) for modular_exp.
10
+ # Make gcd and lcm accept arbitrarly many arguments.
11
+
12
+ from __future__ import division
13
+
14
+ from functools import reduce
15
+
16
+ import math
17
+
18
+
19
+ class Error(Exception):
20
+ """Base class for exceptions in this module."""
21
+ pass
22
+
23
+
24
+ class SquareRootError(Error):
25
+ pass
26
+
27
+
28
+ class NegativeExponentError(Error):
29
+ pass
30
+
31
+
32
+ def modular_exp(base, exponent, modulus):
33
+ "Raise base to exponent, reducing by modulus"
34
+ if exponent < 0:
35
+ raise NegativeExponentError("Negative exponents (%d) not allowed" \
36
+ % exponent)
37
+ return pow(base, exponent, modulus)
38
+
39
+
40
+ # result = 1L
41
+ # x = exponent
42
+ # b = base + 0L
43
+ # while x > 0:
44
+ # if x % 2 > 0: result = (result * b) % modulus
45
+ # x = x // 2
46
+ # b = (b * b) % modulus
47
+ # return result
48
+
49
+
50
+ def polynomial_reduce_mod(poly, polymod, p):
51
+ """Reduce poly by polymod, integer arithmetic modulo p.
52
+
53
+ Polynomials are represented as lists of coefficients
54
+ of increasing powers of x."""
55
+
56
+ # This module has been tested only by extensive use
57
+ # in calculating modular square roots.
58
+
59
+ # Just to make this easy, require a monic polynomial:
60
+ assert polymod[-1] == 1
61
+
62
+ assert len(polymod) > 1
63
+
64
+ while len(poly) >= len(polymod):
65
+ if poly[-1] != 0:
66
+ for i in range(2, len(polymod) + 1):
67
+ poly[-i] = (poly[-i] - poly[-1] * polymod[-i]) % p
68
+ poly = poly[0:-1]
69
+
70
+ return poly
71
+
72
+
73
+ def polynomial_multiply_mod(m1, m2, polymod, p):
74
+ """Polynomial multiplication modulo a polynomial over ints mod p.
75
+
76
+ Polynomials are represented as lists of coefficients
77
+ of increasing powers of x."""
78
+
79
+ # This is just a seat-of-the-pants implementation.
80
+
81
+ # This module has been tested only by extensive use
82
+ # in calculating modular square roots.
83
+
84
+ # Initialize the product to zero:
85
+
86
+ prod = (len(m1) + len(m2) - 1) * [0]
87
+
88
+ # Add together all the cross-terms:
89
+
90
+ for i in range(len(m1)):
91
+ for j in range(len(m2)):
92
+ prod[i + j] = (prod[i + j] + m1[i] * m2[j]) % p
93
+
94
+ return polynomial_reduce_mod(prod, polymod, p)
95
+
96
+
97
+ def polynomial_exp_mod(base, exponent, polymod, p):
98
+ """Polynomial exponentiation modulo a polynomial over ints mod p.
99
+
100
+ Polynomials are represented as lists of coefficients
101
+ of increasing powers of x."""
102
+
103
+ # Based on the Handbook of Applied Cryptography, algorithm 2.227.
104
+
105
+ # This module has been tested only by extensive use
106
+ # in calculating modular square roots.
107
+
108
+ assert exponent < p
109
+
110
+ if exponent == 0:
111
+ return [1]
112
+
113
+ G = base
114
+ k = exponent
115
+ if k % 2 == 1:
116
+ s = G
117
+ else:
118
+ s = [1]
119
+
120
+ while k > 1:
121
+ k = k // 2
122
+ G = polynomial_multiply_mod(G, G, polymod, p)
123
+ if k % 2 == 1:
124
+ s = polynomial_multiply_mod(G, s, polymod, p)
125
+
126
+ return s
127
+
128
+
129
+ def jacobi(a, n):
130
+ """Jacobi symbol"""
131
+
132
+ # Based on the Handbook of Applied Cryptography (HAC), algorithm 2.149.
133
+
134
+ # This function has been tested by comparison with a small
135
+ # table printed in HAC, and by extensive use in calculating
136
+ # modular square roots.
137
+
138
+ assert n >= 3
139
+ assert n % 2 == 1
140
+ a = a % n
141
+ if a == 0:
142
+ return 0
143
+ if a == 1:
144
+ return 1
145
+ a1, e = a, 0
146
+ while a1 % 2 == 0:
147
+ a1, e = a1 // 2, e + 1
148
+ if e % 2 == 0 or n % 8 == 1 or n % 8 == 7:
149
+ s = 1
150
+ else:
151
+ s = -1
152
+ if a1 == 1:
153
+ return s
154
+ if n % 4 == 3 and a1 % 4 == 3:
155
+ s = -s
156
+ return s * jacobi(n % a1, a1)
157
+
158
+
159
+ def square_root_mod_prime(a, p):
160
+ """Modular square root of a, mod p, p prime."""
161
+
162
+ # Based on the Handbook of Applied Cryptography, algorithms 3.34 to 3.39.
163
+
164
+ # This module has been tested for all values in [0,p-1] for
165
+ # every prime p from 3 to 1229.
166
+
167
+ assert 0 <= a < p
168
+ assert 1 < p
169
+
170
+ if a == 0:
171
+ return 0
172
+ if p == 2:
173
+ return a
174
+
175
+ jac = jacobi(a, p)
176
+ if jac == -1:
177
+ raise SquareRootError("%d has no square root modulo %d" \
178
+ % (a, p))
179
+
180
+ if p % 4 == 3:
181
+ return modular_exp(a, (p + 1) // 4, p)
182
+
183
+ if p % 8 == 5:
184
+ d = modular_exp(a, (p - 1) // 4, p)
185
+ if d == 1:
186
+ return modular_exp(a, (p + 3) // 8, p)
187
+ if d == p - 1:
188
+ return (2 * a * modular_exp(4 * a, (p - 5) // 8, p)) % p
189
+ raise RuntimeError("Shouldn't get here.")
190
+
191
+ for b in range(2, p):
192
+ if jacobi(b * b - 4 * a, p) == -1:
193
+ f = (a, -b, 1)
194
+ ff = polynomial_exp_mod((0, 1), (p + 1) // 2, f, p)
195
+ assert ff[1] == 0
196
+ return ff[0]
197
+ raise RuntimeError("No b found.")
198
+
199
+
200
+ def inverse_mod(a, m):
201
+ """Inverse of a mod m."""
202
+
203
+ if a < 0 or m <= a:
204
+ a = a % m
205
+
206
+ # From Ferguson and Schneier, roughly:
207
+
208
+ c, d = a, m
209
+ uc, vc, ud, vd = 1, 0, 0, 1
210
+ while c != 0:
211
+ q, c, d = divmod(d, c) + (c,)
212
+ uc, vc, ud, vd = ud - q * uc, vd - q * vc, uc, vc
213
+
214
+ # At this point, d is the GCD, and ud*a+vd*m = d.
215
+ # If d == 1, this means that ud is a inverse.
216
+
217
+ assert d == 1
218
+ if ud > 0:
219
+ return ud
220
+ else:
221
+ return ud + m
222
+
223
+
224
+ def gcd2(a, b):
225
+ """Greatest common divisor using Euclid's algorithm."""
226
+ while a:
227
+ a, b = b % a, a
228
+ return b
229
+
230
+
231
+ def gcd(*a):
232
+ """Greatest common divisor.
233
+
234
+ Usage: gcd([ 2, 4, 6 ])
235
+ or: gcd(2, 4, 6)
236
+ """
237
+
238
+ if len(a) > 1:
239
+ return reduce(gcd2, a)
240
+ if hasattr(a[0], "__iter__"):
241
+ return reduce(gcd2, a[0])
242
+ return a[0]
243
+
244
+
245
+ def lcm2(a, b):
246
+ """Least common multiple of two integers."""
247
+
248
+ return (a * b) // gcd(a, b)
249
+
250
+
251
+ def lcm(*a):
252
+ """Least common multiple.
253
+
254
+ Usage: lcm([ 3, 4, 5 ])
255
+ or: lcm(3, 4, 5)
256
+ """
257
+
258
+ if len(a) > 1:
259
+ return reduce(lcm2, a)
260
+ if hasattr(a[0], "__iter__"):
261
+ return reduce(lcm2, a[0])
262
+ return a[0]
263
+
264
+
265
+ def factorization(n):
266
+ """Decompose n into a list of (prime,exponent) pairs."""
267
+
268
+ assert isinstance(n, int)
269
+
270
+ if n < 2:
271
+ return []
272
+
273
+ result = []
274
+ d = 2
275
+
276
+ # Test the small primes:
277
+
278
+ for d in smallprimes:
279
+ if d > n:
280
+ break
281
+ q, r = divmod(n, d)
282
+ if r == 0:
283
+ count = 1
284
+ while d <= n:
285
+ n = q
286
+ q, r = divmod(n, d)
287
+ if r != 0:
288
+ break
289
+ count = count + 1
290
+ result.append((d, count))
291
+
292
+ # If n is still greater than the last of our small primes,
293
+ # it may require further work:
294
+
295
+ if n > smallprimes[-1]:
296
+ if is_prime(n): # If what's left is prime, it's easy:
297
+ result.append((n, 1))
298
+ else: # Ugh. Search stupidly for a divisor:
299
+ d = smallprimes[-1]
300
+ while 1:
301
+ d = d + 2 # Try the next divisor.
302
+ q, r = divmod(n, d)
303
+ if q < d: # n < d*d means we're done, n = 1 or prime.
304
+ break
305
+ if r == 0: # d divides n. How many times?
306
+ count = 1
307
+ n = q
308
+ while d <= n: # As long as d might still divide n,
309
+ q, r = divmod(n, d) # see if it does.
310
+ if r != 0:
311
+ break
312
+ n = q # It does. Reduce n, increase count.
313
+ count = count + 1
314
+ result.append((d, count))
315
+ if n > 1:
316
+ result.append((n, 1))
317
+
318
+ return result
319
+
320
+
321
+ def phi(n):
322
+ """Return the Euler totient function of n."""
323
+
324
+ assert isinstance(n, int)
325
+
326
+ if n < 3:
327
+ return 1
328
+
329
+ result = 1
330
+ ff = factorization(n)
331
+ for f in ff:
332
+ e = f[1]
333
+ if e > 1:
334
+ result = result * f[0] ** (e - 1) * (f[0] - 1)
335
+ else:
336
+ result = result * (f[0] - 1)
337
+ return result
338
+
339
+
340
+ def carmichael(n):
341
+ """Return Carmichael function of n.
342
+
343
+ Carmichael(n) is the smallest integer x such that
344
+ m**x = 1 mod n for all m relatively prime to n.
345
+ """
346
+
347
+ return carmichael_of_factorized(factorization(n))
348
+
349
+
350
+ def carmichael_of_factorized(f_list):
351
+ """Return the Carmichael function of a number that is
352
+ represented as a list of (prime,exponent) pairs.
353
+ """
354
+
355
+ if len(f_list) < 1:
356
+ return 1
357
+
358
+ result = carmichael_of_ppower(f_list[0])
359
+ for i in range(1, len(f_list)):
360
+ result = lcm(result, carmichael_of_ppower(f_list[i]))
361
+
362
+ return result
363
+
364
+
365
+ def carmichael_of_ppower(pp):
366
+ """Carmichael function of the given power of the given prime.
367
+ """
368
+
369
+ p, a = pp
370
+ if p == 2 and a > 2:
371
+ return 2 ** (a - 2)
372
+ else:
373
+ return (p - 1) * p ** (a - 1)
374
+
375
+
376
+ def order_mod(x, m):
377
+ """Return the order of x in the multiplicative group mod m.
378
+ """
379
+
380
+ # Warning: this implementation is not very clever, and will
381
+ # take a long time if m is very large.
382
+
383
+ if m <= 1:
384
+ return 0
385
+
386
+ assert gcd(x, m) == 1
387
+
388
+ z = x
389
+ result = 1
390
+ while z != 1:
391
+ z = (z * x) % m
392
+ result = result + 1
393
+ return result
394
+
395
+
396
+ def largest_factor_relatively_prime(a, b):
397
+ """Return the largest factor of a relatively prime to b.
398
+ """
399
+
400
+ while 1:
401
+ d = gcd(a, b)
402
+ if d <= 1:
403
+ break
404
+ b = d
405
+ while 1:
406
+ q, r = divmod(a, d)
407
+ if r > 0:
408
+ break
409
+ a = q
410
+ return a
411
+
412
+
413
+ def kinda_order_mod(x, m):
414
+ """Return the order of x in the multiplicative group mod m',
415
+ where m' is the largest factor of m relatively prime to x.
416
+ """
417
+
418
+ return order_mod(x, largest_factor_relatively_prime(m, x))
419
+
420
+
421
+ def is_prime(n):
422
+ """Return True if x is prime, False otherwise.
423
+
424
+ We use the Miller-Rabin test, as given in Menezes et al. p. 138.
425
+ This test is not exact: there are composite values n for which
426
+ it returns True.
427
+
428
+ In testing the odd numbers from 10000001 to 19999999,
429
+ about 66 composites got past the first test,
430
+ 5 got past the second test, and none got past the third.
431
+ Since factors of 2, 3, 5, 7, and 11 were detected during
432
+ preliminary screening, the number of numbers tested by
433
+ Miller-Rabin was (19999999 - 10000001)*(2/3)*(4/5)*(6/7)
434
+ = 4.57 million.
435
+ """
436
+
437
+ # (This is used to study the risk of false positives:)
438
+ global miller_rabin_test_count
439
+
440
+ miller_rabin_test_count = 0
441
+
442
+ if n <= smallprimes[-1]:
443
+ if n in smallprimes:
444
+ return True
445
+ else:
446
+ return False
447
+
448
+ if gcd(n, 2 * 3 * 5 * 7 * 11) != 1:
449
+ return False
450
+
451
+ # Choose a number of iterations sufficient to reduce the
452
+ # probability of accepting a composite below 2**-80
453
+ # (from Menezes et al. Table 4.4):
454
+
455
+ t = 40
456
+ n_bits = 1 + int(math.log(n, 2))
457
+ for k, tt in ((100, 27),
458
+ (150, 18),
459
+ (200, 15),
460
+ (250, 12),
461
+ (300, 9),
462
+ (350, 8),
463
+ (400, 7),
464
+ (450, 6),
465
+ (550, 5),
466
+ (650, 4),
467
+ (850, 3),
468
+ (1300, 2),
469
+ ):
470
+ if n_bits < k:
471
+ break
472
+ t = tt
473
+
474
+ # Run the test t times:
475
+
476
+ s = 0
477
+ r = n - 1
478
+ while (r % 2) == 0:
479
+ s = s + 1
480
+ r = r // 2
481
+ for i in range(t):
482
+ a = smallprimes[i]
483
+ y = modular_exp(a, r, n)
484
+ if y != 1 and y != n - 1:
485
+ j = 1
486
+ while j <= s - 1 and y != n - 1:
487
+ y = modular_exp(y, 2, n)
488
+ if y == 1:
489
+ miller_rabin_test_count = i + 1
490
+ return False
491
+ j = j + 1
492
+ if y != n - 1:
493
+ miller_rabin_test_count = i + 1
494
+ return False
495
+ return True
496
+
497
+
498
+ def next_prime(starting_value):
499
+ "Return the smallest prime larger than the starting value."
500
+
501
+ if starting_value < 2:
502
+ return 2
503
+ result = (starting_value + 1) | 1
504
+ while not is_prime(result):
505
+ result = result + 2
506
+ return result
507
+
508
+
509
+ smallprimes = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41,
510
+ 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97,
511
+ 101, 103, 107, 109, 113, 127, 131, 137, 139, 149,
512
+ 151, 157, 163, 167, 173, 179, 181, 191, 193, 197,
513
+ 199, 211, 223, 227, 229, 233, 239, 241, 251, 257,
514
+ 263, 269, 271, 277, 281, 283, 293, 307, 311, 313,
515
+ 317, 331, 337, 347, 349, 353, 359, 367, 373, 379,
516
+ 383, 389, 397, 401, 409, 419, 421, 431, 433, 439,
517
+ 443, 449, 457, 461, 463, 467, 479, 487, 491, 499,
518
+ 503, 509, 521, 523, 541, 547, 557, 563, 569, 571,
519
+ 577, 587, 593, 599, 601, 607, 613, 617, 619, 631,
520
+ 641, 643, 647, 653, 659, 661, 673, 677, 683, 691,
521
+ 701, 709, 719, 727, 733, 739, 743, 751, 757, 761,
522
+ 769, 773, 787, 797, 809, 811, 821, 823, 827, 829,
523
+ 839, 853, 857, 859, 863, 877, 881, 883, 887, 907,
524
+ 911, 919, 929, 937, 941, 947, 953, 967, 971, 977,
525
+ 983, 991, 997, 1009, 1013, 1019, 1021, 1031, 1033,
526
+ 1039, 1049, 1051, 1061, 1063, 1069, 1087, 1091, 1093,
527
+ 1097, 1103, 1109, 1117, 1123, 1129, 1151, 1153, 1163,
528
+ 1171, 1181, 1187, 1193, 1201, 1213, 1217, 1223, 1229]
529
+
530
+ miller_rabin_test_count = 0
531
+
@@ -0,0 +1,100 @@
1
+ '''
2
+ RFC 6979:
3
+ Deterministic Usage of the Digital Signature Algorithm (DSA) and
4
+ Elliptic Curve Digital Signature Algorithm (ECDSA)
5
+
6
+ http://tools.ietf.org/html/rfc6979
7
+
8
+ Many thanks to Coda Hale for his implementation in Go language:
9
+ https://github.com/codahale/rfc6979
10
+ '''
11
+
12
+ import hmac
13
+ from binascii import hexlify
14
+ from .util import number_to_string, number_to_string_crop
15
+
16
+
17
+ def bit_length(num):
18
+ # http://docs.python.org/dev/library/stdtypes.html#int.bit_length
19
+ s = bin(num) # binary representation: bin(-37) --> '-0b100101'
20
+ s = s.lstrip('-0b') # remove leading zeros and minus sign
21
+ return len(s) # len('100101') --> 6
22
+
23
+
24
+ def bits2int(data, qlen):
25
+ x = int(hexlify(data), 16)
26
+ l = len(data) * 8
27
+
28
+ if l > qlen:
29
+ return x >> (l - qlen)
30
+ return x
31
+
32
+
33
+ def bits2octets(data, order):
34
+ z1 = bits2int(data, bit_length(order))
35
+ z2 = z1 - order
36
+
37
+ if z2 < 0:
38
+ z2 = z1
39
+
40
+ return number_to_string_crop(z2, order)
41
+
42
+
43
+ # https://tools.ietf.org/html/rfc6979#section-3.2
44
+ def generate_k(order, secexp, hash_func, data, retry_gen=0, extra_entropy=b''):
45
+ '''
46
+ order - order of the DSA generator used in the signature
47
+ secexp - secure exponent (private key) in numeric form
48
+ hash_func - reference to the same hash function used for generating hash
49
+ data - hash in binary form of the signing data
50
+ retry_gen - int - how many good 'k' values to skip before returning
51
+ extra_entropy - extra added data in binary form as per section-3.6 of
52
+ rfc6979
53
+ '''
54
+
55
+ qlen = bit_length(order)
56
+ holen = hash_func().digest_size
57
+ rolen = (qlen + 7) / 8
58
+ bx = number_to_string(secexp, order) + bits2octets(data, order) + \
59
+ extra_entropy
60
+
61
+ # Step B
62
+ v = b'\x01' * holen
63
+
64
+ # Step C
65
+ k = b'\x00' * holen
66
+
67
+ # Step D
68
+
69
+ k = hmac.new(k, v + b'\x00' + bx, hash_func).digest()
70
+
71
+ # Step E
72
+ v = hmac.new(k, v, hash_func).digest()
73
+
74
+ # Step F
75
+ k = hmac.new(k, v + b'\x01' + bx, hash_func).digest()
76
+
77
+ # Step G
78
+ v = hmac.new(k, v, hash_func).digest()
79
+
80
+ # Step H
81
+ while True:
82
+ # Step H1
83
+ t = b''
84
+
85
+ # Step H2
86
+ while len(t) < rolen:
87
+ v = hmac.new(k, v, hash_func).digest()
88
+ t += v
89
+
90
+ # Step H3
91
+ secret = bits2int(t, qlen)
92
+
93
+ if secret >= 1 and secret < order:
94
+ if retry_gen <= 0:
95
+ return secret
96
+ else:
97
+ retry_gen -= 1
98
+
99
+ k = hmac.new(k, v + b'\x00', hash_func).digest()
100
+ v = hmac.new(k, v, hash_func).digest()