coinex-api 0.0.13__py3-none-any.whl → 0.0.14__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.
- coinex/__init__.py +7 -0
- coinex/ccxt/__init__.py +101 -0
- coinex/ccxt/abstract/coinex.py +237 -0
- coinex/ccxt/async_support/__init__.py +80 -0
- coinex/ccxt/async_support/base/__init__.py +1 -0
- coinex/ccxt/async_support/base/exchange.py +2100 -0
- coinex/ccxt/async_support/base/throttler.py +50 -0
- coinex/ccxt/async_support/base/ws/__init__.py +38 -0
- coinex/ccxt/async_support/base/ws/aiohttp_client.py +147 -0
- coinex/ccxt/async_support/base/ws/cache.py +213 -0
- coinex/ccxt/async_support/base/ws/client.py +214 -0
- coinex/ccxt/async_support/base/ws/fast_client.py +97 -0
- coinex/ccxt/async_support/base/ws/functions.py +59 -0
- coinex/ccxt/async_support/base/ws/future.py +69 -0
- coinex/ccxt/async_support/base/ws/order_book.py +78 -0
- coinex/ccxt/async_support/base/ws/order_book_side.py +174 -0
- coinex/ccxt/async_support/coinex.py +5833 -0
- coinex/ccxt/base/__init__.py +27 -0
- coinex/ccxt/base/decimal_to_precision.py +174 -0
- coinex/ccxt/base/errors.py +267 -0
- coinex/ccxt/base/exchange.py +6769 -0
- coinex/ccxt/base/precise.py +297 -0
- coinex/ccxt/base/types.py +577 -0
- coinex/ccxt/coinex.py +5832 -0
- coinex/ccxt/pro/__init__.py +21 -0
- coinex/ccxt/pro/coinex.py +1366 -0
- coinex/ccxt/static_dependencies/README.md +1 -0
- coinex/ccxt/static_dependencies/__init__.py +1 -0
- coinex/ccxt/static_dependencies/ecdsa/__init__.py +14 -0
- coinex/ccxt/static_dependencies/ecdsa/_version.py +520 -0
- coinex/ccxt/static_dependencies/ecdsa/curves.py +56 -0
- coinex/ccxt/static_dependencies/ecdsa/der.py +221 -0
- coinex/ccxt/static_dependencies/ecdsa/ecdsa.py +310 -0
- coinex/ccxt/static_dependencies/ecdsa/ellipticcurve.py +197 -0
- coinex/ccxt/static_dependencies/ecdsa/keys.py +332 -0
- coinex/ccxt/static_dependencies/ecdsa/numbertheory.py +531 -0
- coinex/ccxt/static_dependencies/ecdsa/rfc6979.py +100 -0
- coinex/ccxt/static_dependencies/ecdsa/util.py +266 -0
- coinex/ccxt/static_dependencies/ethereum/__init__.py +7 -0
- coinex/ccxt/static_dependencies/ethereum/abi/__init__.py +16 -0
- coinex/ccxt/static_dependencies/ethereum/abi/abi.py +19 -0
- coinex/ccxt/static_dependencies/ethereum/abi/base.py +152 -0
- coinex/ccxt/static_dependencies/ethereum/abi/codec.py +217 -0
- coinex/ccxt/static_dependencies/ethereum/abi/constants.py +3 -0
- coinex/ccxt/static_dependencies/ethereum/abi/decoding.py +565 -0
- coinex/ccxt/static_dependencies/ethereum/abi/encoding.py +720 -0
- coinex/ccxt/static_dependencies/ethereum/abi/exceptions.py +139 -0
- coinex/ccxt/static_dependencies/ethereum/abi/grammar.py +443 -0
- coinex/ccxt/static_dependencies/ethereum/abi/packed.py +13 -0
- coinex/ccxt/static_dependencies/ethereum/abi/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/abi/registry.py +643 -0
- coinex/ccxt/static_dependencies/ethereum/abi/tools/__init__.py +3 -0
- coinex/ccxt/static_dependencies/ethereum/abi/tools/_strategies.py +230 -0
- coinex/ccxt/static_dependencies/ethereum/abi/utils/__init__.py +0 -0
- coinex/ccxt/static_dependencies/ethereum/abi/utils/numeric.py +83 -0
- coinex/ccxt/static_dependencies/ethereum/abi/utils/padding.py +27 -0
- coinex/ccxt/static_dependencies/ethereum/abi/utils/string.py +19 -0
- coinex/ccxt/static_dependencies/ethereum/account/__init__.py +3 -0
- coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/__init__.py +4 -0
- coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/encoding_and_hashing.py +239 -0
- coinex/ccxt/static_dependencies/ethereum/account/encode_typed_data/helpers.py +40 -0
- coinex/ccxt/static_dependencies/ethereum/account/messages.py +263 -0
- coinex/ccxt/static_dependencies/ethereum/account/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/hexbytes/__init__.py +5 -0
- coinex/ccxt/static_dependencies/ethereum/hexbytes/_utils.py +54 -0
- coinex/ccxt/static_dependencies/ethereum/hexbytes/main.py +65 -0
- coinex/ccxt/static_dependencies/ethereum/hexbytes/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/typing/__init__.py +63 -0
- coinex/ccxt/static_dependencies/ethereum/typing/abi.py +6 -0
- coinex/ccxt/static_dependencies/ethereum/typing/bls.py +7 -0
- coinex/ccxt/static_dependencies/ethereum/typing/discovery.py +5 -0
- coinex/ccxt/static_dependencies/ethereum/typing/encoding.py +7 -0
- coinex/ccxt/static_dependencies/ethereum/typing/enums.py +17 -0
- coinex/ccxt/static_dependencies/ethereum/typing/ethpm.py +9 -0
- coinex/ccxt/static_dependencies/ethereum/typing/evm.py +20 -0
- coinex/ccxt/static_dependencies/ethereum/typing/networks.py +1122 -0
- coinex/ccxt/static_dependencies/ethereum/typing/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/utils/__init__.py +115 -0
- coinex/ccxt/static_dependencies/ethereum/utils/abi.py +72 -0
- coinex/ccxt/static_dependencies/ethereum/utils/address.py +171 -0
- coinex/ccxt/static_dependencies/ethereum/utils/applicators.py +151 -0
- coinex/ccxt/static_dependencies/ethereum/utils/conversions.py +190 -0
- coinex/ccxt/static_dependencies/ethereum/utils/currency.py +107 -0
- coinex/ccxt/static_dependencies/ethereum/utils/curried/__init__.py +269 -0
- coinex/ccxt/static_dependencies/ethereum/utils/debug.py +20 -0
- coinex/ccxt/static_dependencies/ethereum/utils/decorators.py +132 -0
- coinex/ccxt/static_dependencies/ethereum/utils/encoding.py +6 -0
- coinex/ccxt/static_dependencies/ethereum/utils/exceptions.py +4 -0
- coinex/ccxt/static_dependencies/ethereum/utils/functional.py +75 -0
- coinex/ccxt/static_dependencies/ethereum/utils/hexadecimal.py +74 -0
- coinex/ccxt/static_dependencies/ethereum/utils/humanize.py +188 -0
- coinex/ccxt/static_dependencies/ethereum/utils/logging.py +159 -0
- coinex/ccxt/static_dependencies/ethereum/utils/module_loading.py +31 -0
- coinex/ccxt/static_dependencies/ethereum/utils/numeric.py +43 -0
- coinex/ccxt/static_dependencies/ethereum/utils/py.typed +0 -0
- coinex/ccxt/static_dependencies/ethereum/utils/toolz.py +76 -0
- coinex/ccxt/static_dependencies/ethereum/utils/types.py +54 -0
- coinex/ccxt/static_dependencies/ethereum/utils/typing/__init__.py +18 -0
- coinex/ccxt/static_dependencies/ethereum/utils/typing/misc.py +14 -0
- coinex/ccxt/static_dependencies/ethereum/utils/units.py +31 -0
- coinex/ccxt/static_dependencies/keccak/__init__.py +3 -0
- coinex/ccxt/static_dependencies/keccak/keccak.py +197 -0
- coinex/ccxt/static_dependencies/lark/__init__.py +38 -0
- coinex/ccxt/static_dependencies/lark/__pyinstaller/__init__.py +6 -0
- coinex/ccxt/static_dependencies/lark/__pyinstaller/hook-lark.py +14 -0
- coinex/ccxt/static_dependencies/lark/ast_utils.py +59 -0
- coinex/ccxt/static_dependencies/lark/common.py +86 -0
- coinex/ccxt/static_dependencies/lark/exceptions.py +292 -0
- coinex/ccxt/static_dependencies/lark/grammar.py +130 -0
- coinex/ccxt/static_dependencies/lark/grammars/__init__.py +0 -0
- coinex/ccxt/static_dependencies/lark/grammars/common.lark +59 -0
- coinex/ccxt/static_dependencies/lark/grammars/lark.lark +62 -0
- coinex/ccxt/static_dependencies/lark/grammars/python.lark +302 -0
- coinex/ccxt/static_dependencies/lark/grammars/unicode.lark +7 -0
- coinex/ccxt/static_dependencies/lark/indenter.py +143 -0
- coinex/ccxt/static_dependencies/lark/lark.py +658 -0
- coinex/ccxt/static_dependencies/lark/lexer.py +678 -0
- coinex/ccxt/static_dependencies/lark/load_grammar.py +1428 -0
- coinex/ccxt/static_dependencies/lark/parse_tree_builder.py +391 -0
- coinex/ccxt/static_dependencies/lark/parser_frontends.py +257 -0
- coinex/ccxt/static_dependencies/lark/parsers/__init__.py +0 -0
- coinex/ccxt/static_dependencies/lark/parsers/cyk.py +340 -0
- coinex/ccxt/static_dependencies/lark/parsers/earley.py +314 -0
- coinex/ccxt/static_dependencies/lark/parsers/earley_common.py +42 -0
- coinex/ccxt/static_dependencies/lark/parsers/earley_forest.py +801 -0
- coinex/ccxt/static_dependencies/lark/parsers/grammar_analysis.py +203 -0
- coinex/ccxt/static_dependencies/lark/parsers/lalr_analysis.py +332 -0
- coinex/ccxt/static_dependencies/lark/parsers/lalr_interactive_parser.py +158 -0
- coinex/ccxt/static_dependencies/lark/parsers/lalr_parser.py +122 -0
- coinex/ccxt/static_dependencies/lark/parsers/lalr_parser_state.py +110 -0
- coinex/ccxt/static_dependencies/lark/parsers/xearley.py +165 -0
- coinex/ccxt/static_dependencies/lark/py.typed +0 -0
- coinex/ccxt/static_dependencies/lark/reconstruct.py +107 -0
- coinex/ccxt/static_dependencies/lark/tools/__init__.py +70 -0
- coinex/ccxt/static_dependencies/lark/tools/nearley.py +202 -0
- coinex/ccxt/static_dependencies/lark/tools/serialize.py +32 -0
- coinex/ccxt/static_dependencies/lark/tools/standalone.py +196 -0
- coinex/ccxt/static_dependencies/lark/tree.py +267 -0
- coinex/ccxt/static_dependencies/lark/tree_matcher.py +186 -0
- coinex/ccxt/static_dependencies/lark/tree_templates.py +180 -0
- coinex/ccxt/static_dependencies/lark/utils.py +343 -0
- coinex/ccxt/static_dependencies/lark/visitors.py +596 -0
- coinex/ccxt/static_dependencies/marshmallow/__init__.py +81 -0
- coinex/ccxt/static_dependencies/marshmallow/base.py +65 -0
- coinex/ccxt/static_dependencies/marshmallow/class_registry.py +94 -0
- coinex/ccxt/static_dependencies/marshmallow/decorators.py +231 -0
- coinex/ccxt/static_dependencies/marshmallow/error_store.py +60 -0
- coinex/ccxt/static_dependencies/marshmallow/exceptions.py +71 -0
- coinex/ccxt/static_dependencies/marshmallow/fields.py +2114 -0
- coinex/ccxt/static_dependencies/marshmallow/orderedset.py +89 -0
- coinex/ccxt/static_dependencies/marshmallow/py.typed +0 -0
- coinex/ccxt/static_dependencies/marshmallow/schema.py +1228 -0
- coinex/ccxt/static_dependencies/marshmallow/types.py +12 -0
- coinex/ccxt/static_dependencies/marshmallow/utils.py +378 -0
- coinex/ccxt/static_dependencies/marshmallow/validate.py +678 -0
- coinex/ccxt/static_dependencies/marshmallow/warnings.py +2 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/__init__.py +1047 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/collection_field.py +51 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/lazy_class_attribute.py +45 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/mypy.py +71 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/py.typed +0 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/typing.py +14 -0
- coinex/ccxt/static_dependencies/marshmallow_dataclass/union_field.py +82 -0
- coinex/ccxt/static_dependencies/marshmallow_oneofschema/__init__.py +1 -0
- coinex/ccxt/static_dependencies/marshmallow_oneofschema/one_of_schema.py +193 -0
- coinex/ccxt/static_dependencies/marshmallow_oneofschema/py.typed +0 -0
- coinex/ccxt/static_dependencies/msgpack/__init__.py +55 -0
- coinex/ccxt/static_dependencies/msgpack/_cmsgpack.pyx +11 -0
- coinex/ccxt/static_dependencies/msgpack/_packer.pyx +374 -0
- coinex/ccxt/static_dependencies/msgpack/_unpacker.pyx +547 -0
- coinex/ccxt/static_dependencies/msgpack/buff_converter.h +8 -0
- coinex/ccxt/static_dependencies/msgpack/exceptions.py +48 -0
- coinex/ccxt/static_dependencies/msgpack/ext.py +168 -0
- coinex/ccxt/static_dependencies/msgpack/fallback.py +951 -0
- coinex/ccxt/static_dependencies/msgpack/pack.h +89 -0
- coinex/ccxt/static_dependencies/msgpack/pack_template.h +820 -0
- coinex/ccxt/static_dependencies/msgpack/sysdep.h +194 -0
- coinex/ccxt/static_dependencies/msgpack/unpack.h +391 -0
- coinex/ccxt/static_dependencies/msgpack/unpack_define.h +95 -0
- coinex/ccxt/static_dependencies/msgpack/unpack_template.h +464 -0
- coinex/ccxt/static_dependencies/parsimonious/__init__.py +10 -0
- coinex/ccxt/static_dependencies/parsimonious/exceptions.py +105 -0
- coinex/ccxt/static_dependencies/parsimonious/expressions.py +479 -0
- coinex/ccxt/static_dependencies/parsimonious/grammar.py +487 -0
- coinex/ccxt/static_dependencies/parsimonious/nodes.py +325 -0
- coinex/ccxt/static_dependencies/parsimonious/utils.py +40 -0
- coinex/ccxt/static_dependencies/starknet/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/__init__.py +2 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/model.py +44 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/parser.py +216 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/schemas.py +72 -0
- coinex/ccxt/static_dependencies/starknet/abi/v0/shape.py +63 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/__init__.py +2 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/core_structures.json +14 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/model.py +39 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/parser.py +220 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/parser_transformer.py +179 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/schemas.py +66 -0
- coinex/ccxt/static_dependencies/starknet/abi/v1/shape.py +47 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/__init__.py +2 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/model.py +89 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/parser.py +293 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/parser_transformer.py +192 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/schemas.py +132 -0
- coinex/ccxt/static_dependencies/starknet/abi/v2/shape.py +107 -0
- coinex/ccxt/static_dependencies/starknet/cairo/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/cairo/data_types.py +123 -0
- coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/cairo_types.py +77 -0
- coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser.py +46 -0
- coinex/ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser_transformer.py +138 -0
- coinex/ccxt/static_dependencies/starknet/cairo/felt.py +64 -0
- coinex/ccxt/static_dependencies/starknet/cairo/type_parser.py +121 -0
- coinex/ccxt/static_dependencies/starknet/cairo/v1/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/cairo/v1/type_parser.py +59 -0
- coinex/ccxt/static_dependencies/starknet/cairo/v2/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/cairo/v2/type_parser.py +77 -0
- coinex/ccxt/static_dependencies/starknet/ccxt_utils.py +7 -0
- coinex/ccxt/static_dependencies/starknet/common.py +15 -0
- coinex/ccxt/static_dependencies/starknet/constants.py +39 -0
- coinex/ccxt/static_dependencies/starknet/hash/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/hash/address.py +79 -0
- coinex/ccxt/static_dependencies/starknet/hash/compiled_class_hash_objects.py +111 -0
- coinex/ccxt/static_dependencies/starknet/hash/selector.py +16 -0
- coinex/ccxt/static_dependencies/starknet/hash/storage.py +12 -0
- coinex/ccxt/static_dependencies/starknet/hash/utils.py +78 -0
- coinex/ccxt/static_dependencies/starknet/models/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/models/typed_data.py +45 -0
- coinex/ccxt/static_dependencies/starknet/serialization/__init__.py +24 -0
- coinex/ccxt/static_dependencies/starknet/serialization/_calldata_reader.py +40 -0
- coinex/ccxt/static_dependencies/starknet/serialization/_context.py +142 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/__init__.py +10 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/_common.py +82 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/array_serializer.py +43 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/bool_serializer.py +37 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/byte_array_serializer.py +66 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/cairo_data_serializer.py +71 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/enum_serializer.py +71 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/felt_serializer.py +50 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/named_tuple_serializer.py +58 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/option_serializer.py +43 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/output_serializer.py +40 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/payload_serializer.py +72 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/struct_serializer.py +36 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/tuple_serializer.py +36 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/uint256_serializer.py +76 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/uint_serializer.py +100 -0
- coinex/ccxt/static_dependencies/starknet/serialization/data_serializers/unit_serializer.py +32 -0
- coinex/ccxt/static_dependencies/starknet/serialization/errors.py +10 -0
- coinex/ccxt/static_dependencies/starknet/serialization/factory.py +229 -0
- coinex/ccxt/static_dependencies/starknet/serialization/function_serialization_adapter.py +110 -0
- coinex/ccxt/static_dependencies/starknet/serialization/tuple_dataclass.py +59 -0
- coinex/ccxt/static_dependencies/starknet/utils/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starknet/utils/constructor_args_translator.py +86 -0
- coinex/ccxt/static_dependencies/starknet/utils/iterable.py +13 -0
- coinex/ccxt/static_dependencies/starknet/utils/schema.py +13 -0
- coinex/ccxt/static_dependencies/starknet/utils/typed_data.py +182 -0
- coinex/ccxt/static_dependencies/starkware/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starkware/crypto/__init__.py +0 -0
- coinex/ccxt/static_dependencies/starkware/crypto/fast_pedersen_hash.py +50 -0
- coinex/ccxt/static_dependencies/starkware/crypto/math_utils.py +78 -0
- coinex/ccxt/static_dependencies/starkware/crypto/signature.py +2344 -0
- coinex/ccxt/static_dependencies/starkware/crypto/utils.py +63 -0
- coinex/ccxt/static_dependencies/sympy/__init__.py +0 -0
- coinex/ccxt/static_dependencies/sympy/core/__init__.py +0 -0
- coinex/ccxt/static_dependencies/sympy/core/intfunc.py +35 -0
- coinex/ccxt/static_dependencies/sympy/external/__init__.py +0 -0
- coinex/ccxt/static_dependencies/sympy/external/gmpy.py +345 -0
- coinex/ccxt/static_dependencies/sympy/external/importtools.py +187 -0
- coinex/ccxt/static_dependencies/sympy/external/ntheory.py +637 -0
- coinex/ccxt/static_dependencies/sympy/external/pythonmpq.py +341 -0
- coinex/ccxt/static_dependencies/toolz/__init__.py +26 -0
- coinex/ccxt/static_dependencies/toolz/_signatures.py +784 -0
- coinex/ccxt/static_dependencies/toolz/_version.py +520 -0
- coinex/ccxt/static_dependencies/toolz/compatibility.py +30 -0
- coinex/ccxt/static_dependencies/toolz/curried/__init__.py +101 -0
- coinex/ccxt/static_dependencies/toolz/curried/exceptions.py +22 -0
- coinex/ccxt/static_dependencies/toolz/curried/operator.py +22 -0
- coinex/ccxt/static_dependencies/toolz/dicttoolz.py +339 -0
- coinex/ccxt/static_dependencies/toolz/functoolz.py +1049 -0
- coinex/ccxt/static_dependencies/toolz/itertoolz.py +1057 -0
- coinex/ccxt/static_dependencies/toolz/recipes.py +46 -0
- coinex/ccxt/static_dependencies/toolz/utils.py +9 -0
- coinex/ccxt/static_dependencies/typing_inspect/__init__.py +0 -0
- coinex/ccxt/static_dependencies/typing_inspect/typing_inspect.py +851 -0
- {coinex_api-0.0.13.dist-info → coinex_api-0.0.14.dist-info}/METADATA +1 -1
- coinex_api-0.0.14.dist-info/RECORD +288 -0
- coinex_api-0.0.13.dist-info/RECORD +0 -3
- {coinex_api-0.0.13.dist-info → coinex_api-0.0.14.dist-info}/WHEEL +0 -0
@@ -0,0 +1,121 @@
|
|
1
|
+
from __future__ import annotations
|
2
|
+
|
3
|
+
from collections import OrderedDict
|
4
|
+
from typing import Dict, cast
|
5
|
+
|
6
|
+
from .deprecated_parse import cairo_types as cairo_lang_types
|
7
|
+
from .data_types import (
|
8
|
+
ArrayType,
|
9
|
+
CairoType,
|
10
|
+
FeltType,
|
11
|
+
NamedTupleType,
|
12
|
+
StructType,
|
13
|
+
TupleType,
|
14
|
+
)
|
15
|
+
from .deprecated_parse.parser import parse
|
16
|
+
|
17
|
+
|
18
|
+
class UnknownCairoTypeError(ValueError):
|
19
|
+
"""
|
20
|
+
Error thrown when TypeParser finds type that was not declared prior to parsing.
|
21
|
+
"""
|
22
|
+
|
23
|
+
type_name: str
|
24
|
+
|
25
|
+
def __init__(self, type_name: str):
|
26
|
+
super().__init__(f"Type '{type_name}' is not defined")
|
27
|
+
self.type_name = type_name
|
28
|
+
|
29
|
+
|
30
|
+
class TypeParser:
|
31
|
+
"""
|
32
|
+
Low level utility class for parsing Cairo types that can be used in external methods.
|
33
|
+
"""
|
34
|
+
|
35
|
+
defined_types: Dict[str, StructType]
|
36
|
+
|
37
|
+
def __init__(self, defined_types: Dict[str, StructType]):
|
38
|
+
"""
|
39
|
+
TypeParser constructor.
|
40
|
+
|
41
|
+
:param defined_types: dictionary containing all defined types. For now, they can only be structures.
|
42
|
+
"""
|
43
|
+
self.defined_types = defined_types
|
44
|
+
for name, struct in defined_types.items():
|
45
|
+
if name != struct.name:
|
46
|
+
raise ValueError(
|
47
|
+
f"Keys must match name of type, '{name}' != '{struct.name}'."
|
48
|
+
)
|
49
|
+
|
50
|
+
def parse_inline_type(self, type_string: str) -> CairoType:
|
51
|
+
"""
|
52
|
+
Inline type is one that can be used inline, for instance as return type. For instance
|
53
|
+
(a: Uint256, b: felt*, c: (felt, felt)). Structure can only be referenced in inline type, can't be defined
|
54
|
+
this way.
|
55
|
+
|
56
|
+
:param type_string: type to parse.
|
57
|
+
"""
|
58
|
+
parsed = parse(type_string)
|
59
|
+
return self._transform_cairo_lang_type(parsed)
|
60
|
+
|
61
|
+
def _transform_cairo_lang_type(
|
62
|
+
self, cairo_type: cairo_lang_types.CairoType
|
63
|
+
) -> CairoType:
|
64
|
+
"""
|
65
|
+
For now, we use parse function from cairo-lang package. It will be replaced in the future, but we need to hide
|
66
|
+
it from the users.
|
67
|
+
This function takes types returned by cairo-lang package and maps them to our type classes.
|
68
|
+
|
69
|
+
:param cairo_type: type returned from parse_type function.
|
70
|
+
:return: CairoType defined by our package.
|
71
|
+
"""
|
72
|
+
if isinstance(cairo_type, cairo_lang_types.TypeFelt):
|
73
|
+
return FeltType()
|
74
|
+
|
75
|
+
if isinstance(cairo_type, cairo_lang_types.TypePointer):
|
76
|
+
return ArrayType(self._transform_cairo_lang_type(cairo_type.pointee))
|
77
|
+
|
78
|
+
if isinstance(cairo_type, cairo_lang_types.TypeIdentifier):
|
79
|
+
return self._get_struct(str(cairo_type.name))
|
80
|
+
|
81
|
+
if isinstance(cairo_type, cairo_lang_types.TypeTuple):
|
82
|
+
# Cairo returns is_named when there are no members
|
83
|
+
if cairo_type.is_named and len(cairo_type.members) != 0:
|
84
|
+
assert all(member.name is not None for member in cairo_type.members)
|
85
|
+
|
86
|
+
return NamedTupleType(
|
87
|
+
OrderedDict(
|
88
|
+
(
|
89
|
+
cast(
|
90
|
+
str, member.name
|
91
|
+
), # without that pyright is complaining
|
92
|
+
self._transform_cairo_lang_type(member.typ),
|
93
|
+
)
|
94
|
+
for member in cairo_type.members
|
95
|
+
)
|
96
|
+
)
|
97
|
+
|
98
|
+
return TupleType(
|
99
|
+
[
|
100
|
+
self._transform_cairo_lang_type(member.typ)
|
101
|
+
for member in cairo_type.members
|
102
|
+
]
|
103
|
+
)
|
104
|
+
|
105
|
+
# Contracts don't support codeoffset as input/output type, user can only use it if it was defined in types
|
106
|
+
if isinstance(cairo_type, cairo_lang_types.TypeCodeoffset):
|
107
|
+
return self._get_struct("codeoffset")
|
108
|
+
|
109
|
+
# Other options are: TypeFunction, TypeStruct
|
110
|
+
# Neither of them are possible. In particular TypeStruct is not possible because we parse structs without
|
111
|
+
# info about other structs, so they will be just TypeIdentifier (structure that was not parsed).
|
112
|
+
|
113
|
+
# This is an error of our logic, so we throw a RuntimeError.
|
114
|
+
raise RuntimeError(
|
115
|
+
f"Received unknown type '{cairo_type}' from parser."
|
116
|
+
) # pragma: no cover
|
117
|
+
|
118
|
+
def _get_struct(self, name: str):
|
119
|
+
if name not in self.defined_types:
|
120
|
+
raise UnknownCairoTypeError(name)
|
121
|
+
return self.defined_types[name]
|
File without changes
|
@@ -0,0 +1,59 @@
|
|
1
|
+
from __future__ import annotations
|
2
|
+
|
3
|
+
from typing import Dict, Union
|
4
|
+
|
5
|
+
from ...abi.v1.parser_transformer import parse
|
6
|
+
from ..data_types import CairoType, EnumType, StructType, TypeIdentifier
|
7
|
+
|
8
|
+
|
9
|
+
class UnknownCairoTypeError(ValueError):
|
10
|
+
"""
|
11
|
+
Error thrown when TypeParser finds type that was not declared prior to parsing.
|
12
|
+
"""
|
13
|
+
|
14
|
+
type_name: str
|
15
|
+
|
16
|
+
def __init__(self, type_name: str):
|
17
|
+
super().__init__(
|
18
|
+
# pylint: disable=line-too-long
|
19
|
+
f"Type '{type_name}' is not defined. Please report this issue at https://github.com/software-mansion/starknet.py/issues"
|
20
|
+
)
|
21
|
+
self.type_name = type_name
|
22
|
+
|
23
|
+
|
24
|
+
class TypeParser:
|
25
|
+
"""
|
26
|
+
Low level utility class for parsing Cairo types that can be used in external methods.
|
27
|
+
"""
|
28
|
+
|
29
|
+
defined_types: Dict[str, Union[StructType, EnumType]]
|
30
|
+
|
31
|
+
def __init__(self, defined_types: Dict[str, Union[StructType, EnumType]]):
|
32
|
+
"""
|
33
|
+
TypeParser constructor.
|
34
|
+
|
35
|
+
:param defined_types: dictionary containing all defined types. For now, they can only be structures.
|
36
|
+
"""
|
37
|
+
self.defined_types = defined_types
|
38
|
+
for name, defined_type in defined_types.items():
|
39
|
+
if name != defined_type.name:
|
40
|
+
raise ValueError(
|
41
|
+
f"Keys must match name of type, '{name}' != '{defined_type.name}'."
|
42
|
+
)
|
43
|
+
|
44
|
+
def parse_inline_type(self, type_string: str) -> CairoType:
|
45
|
+
"""
|
46
|
+
Inline type is one that can be used inline, for instance as return type. For instance
|
47
|
+
(core::felt252, (), (core::felt252,)). Structure can only be referenced in inline type, can't be defined
|
48
|
+
this way.
|
49
|
+
|
50
|
+
:param type_string: type to parse.
|
51
|
+
"""
|
52
|
+
parsed = parse(type_string, self.defined_types)
|
53
|
+
if isinstance(parsed, TypeIdentifier):
|
54
|
+
for defined_name in self.defined_types.keys():
|
55
|
+
if parsed.name == defined_name.split("<")[0].strip(":"):
|
56
|
+
return self.defined_types[defined_name]
|
57
|
+
raise UnknownCairoTypeError(parsed.name)
|
58
|
+
|
59
|
+
return parsed
|
File without changes
|
@@ -0,0 +1,77 @@
|
|
1
|
+
from __future__ import annotations
|
2
|
+
|
3
|
+
from typing import Dict, Union
|
4
|
+
|
5
|
+
from ...abi.v2.parser_transformer import parse
|
6
|
+
from ..data_types import (
|
7
|
+
CairoType,
|
8
|
+
EnumType,
|
9
|
+
EventType,
|
10
|
+
StructType,
|
11
|
+
TypeIdentifier,
|
12
|
+
)
|
13
|
+
|
14
|
+
|
15
|
+
class UnknownCairoTypeError(ValueError):
|
16
|
+
"""
|
17
|
+
Error thrown when TypeParser finds type that was not declared prior to parsing.
|
18
|
+
"""
|
19
|
+
|
20
|
+
type_name: str
|
21
|
+
|
22
|
+
def __init__(self, type_name: str):
|
23
|
+
super().__init__(
|
24
|
+
# pylint: disable=line-too-long
|
25
|
+
f"Type '{type_name}' is not defined. Please report this issue at https://github.com/software-mansion/starknet.py/issues"
|
26
|
+
)
|
27
|
+
self.type_name = type_name
|
28
|
+
|
29
|
+
|
30
|
+
class TypeParser:
|
31
|
+
"""
|
32
|
+
Low level utility class for parsing Cairo types that can be used in external methods.
|
33
|
+
"""
|
34
|
+
|
35
|
+
defined_types: Dict[str, Union[StructType, EnumType, EventType]]
|
36
|
+
|
37
|
+
def __init__(
|
38
|
+
self, defined_types: Dict[str, Union[StructType, EnumType, EventType]]
|
39
|
+
):
|
40
|
+
"""
|
41
|
+
TypeParser constructor.
|
42
|
+
|
43
|
+
:param defined_types: dictionary containing all defined types. For now, they can only be structures.
|
44
|
+
"""
|
45
|
+
self.defined_types = defined_types
|
46
|
+
for name, defined_type in defined_types.items():
|
47
|
+
if name != defined_type.name:
|
48
|
+
raise ValueError(
|
49
|
+
f"Keys must match name of type, '{name}' != '{defined_type.name}'."
|
50
|
+
)
|
51
|
+
|
52
|
+
def update_defined_types(
|
53
|
+
self, defined_types: Dict[str, Union[StructType, EnumType, EventType]]
|
54
|
+
) -> None:
|
55
|
+
self.defined_types.update(defined_types)
|
56
|
+
|
57
|
+
def add_defined_type(
|
58
|
+
self, defined_type: Union[StructType, EnumType, EventType]
|
59
|
+
) -> None:
|
60
|
+
self.defined_types.update({defined_type.name: defined_type})
|
61
|
+
|
62
|
+
def parse_inline_type(self, type_string: str) -> CairoType:
|
63
|
+
"""
|
64
|
+
Inline type is one that can be used inline, for instance as return type. For instance
|
65
|
+
(core::felt252, (), (core::felt252,)). Structure can only be referenced in inline type, can't be defined
|
66
|
+
this way.
|
67
|
+
|
68
|
+
:param type_string: type to parse.
|
69
|
+
"""
|
70
|
+
parsed = parse(type_string, self.defined_types)
|
71
|
+
if isinstance(parsed, TypeIdentifier):
|
72
|
+
for defined_name in self.defined_types.keys():
|
73
|
+
if parsed.name == defined_name.split("<")[0].strip(":"):
|
74
|
+
return self.defined_types[defined_name]
|
75
|
+
raise UnknownCairoTypeError(parsed.name)
|
76
|
+
|
77
|
+
return parsed
|
@@ -0,0 +1,7 @@
|
|
1
|
+
# utils to use starknet library in ccxt
|
2
|
+
from .constants import EC_ORDER
|
3
|
+
from ..starkware.crypto.signature import grind_key
|
4
|
+
|
5
|
+
def get_private_key_from_eth_signature(eth_signature_hex: str) -> int:
|
6
|
+
r = eth_signature_hex[2 : 64 + 2] if eth_signature_hex[0:2] == '0x' else eth_signature_hex[0 : 64]
|
7
|
+
return grind_key(int(r, 16), EC_ORDER)
|
@@ -0,0 +1,15 @@
|
|
1
|
+
from typing import Literal, Union
|
2
|
+
|
3
|
+
def int_from_hex(number: Union[str, int]) -> int:
|
4
|
+
return number if isinstance(number, int) else int(number, 16)
|
5
|
+
|
6
|
+
|
7
|
+
def int_from_bytes(
|
8
|
+
value: bytes,
|
9
|
+
byte_order: Literal["big", "little"] = "big",
|
10
|
+
signed: bool = False,
|
11
|
+
) -> int:
|
12
|
+
"""
|
13
|
+
Converts the given bytes object (parsed according to the given byte order) to an integer.
|
14
|
+
"""
|
15
|
+
return int.from_bytes(value, byteorder=byte_order, signed=signed)
|
@@ -0,0 +1,39 @@
|
|
1
|
+
from pathlib import Path
|
2
|
+
|
3
|
+
# Address came from starkware-libs/starknet-addresses repository: https://github.com/starkware-libs/starknet-addresses
|
4
|
+
FEE_CONTRACT_ADDRESS = (
|
5
|
+
"0x049d36570d4e46f48e99674bd3fcc84644ddd6b96f7c741b1562b82f9e004dc7"
|
6
|
+
)
|
7
|
+
|
8
|
+
DEFAULT_DEPLOYER_ADDRESS = (
|
9
|
+
"0x041a78e741e5aF2fEc34B695679bC6891742439f7AFB8484Ecd7766661aD02BF"
|
10
|
+
)
|
11
|
+
|
12
|
+
API_VERSION = 0
|
13
|
+
|
14
|
+
RPC_CONTRACT_NOT_FOUND_ERROR = 20
|
15
|
+
RPC_INVALID_MESSAGE_SELECTOR_ERROR = 21
|
16
|
+
RPC_CLASS_HASH_NOT_FOUND_ERROR = 28
|
17
|
+
RPC_CONTRACT_ERROR = 40
|
18
|
+
|
19
|
+
DEFAULT_ENTRY_POINT_NAME = "__default__"
|
20
|
+
DEFAULT_L1_ENTRY_POINT_NAME = "__l1_default__"
|
21
|
+
DEFAULT_ENTRY_POINT_SELECTOR = 0
|
22
|
+
DEFAULT_DECLARE_SENDER_ADDRESS = 1
|
23
|
+
|
24
|
+
# MAX_STORAGE_ITEM_SIZE and ADDR_BOUND must be consistent with the corresponding constant in
|
25
|
+
# starkware/starknet/common/storage.cairo.
|
26
|
+
MAX_STORAGE_ITEM_SIZE = 256
|
27
|
+
ADDR_BOUND = 2**251 - MAX_STORAGE_ITEM_SIZE
|
28
|
+
|
29
|
+
FIELD_PRIME = 0x800000000000011000000000000000000000000000000000000000000000001
|
30
|
+
EC_ORDER = 0x800000000000010FFFFFFFFFFFFFFFFB781126DCAE7B2321E66A241ADC64D2F
|
31
|
+
|
32
|
+
# From cairo-lang
|
33
|
+
# int_from_bytes(b"STARKNET_CONTRACT_ADDRESS")
|
34
|
+
CONTRACT_ADDRESS_PREFIX = 523065374597054866729014270389667305596563390979550329787219
|
35
|
+
L2_ADDRESS_UPPER_BOUND = 2**251 - 256
|
36
|
+
|
37
|
+
QUERY_VERSION_BASE = 2**128
|
38
|
+
|
39
|
+
ROOT_PATH = Path(__file__).parent
|
File without changes
|
@@ -0,0 +1,79 @@
|
|
1
|
+
from typing import Sequence
|
2
|
+
|
3
|
+
from ..constants import CONTRACT_ADDRESS_PREFIX, L2_ADDRESS_UPPER_BOUND
|
4
|
+
from .utils import (
|
5
|
+
HEX_PREFIX,
|
6
|
+
_starknet_keccak,
|
7
|
+
compute_hash_on_elements,
|
8
|
+
encode_uint,
|
9
|
+
get_bytes_length,
|
10
|
+
)
|
11
|
+
|
12
|
+
|
13
|
+
def compute_address(
|
14
|
+
*,
|
15
|
+
class_hash: int,
|
16
|
+
constructor_calldata: Sequence[int],
|
17
|
+
salt: int,
|
18
|
+
deployer_address: int = 0,
|
19
|
+
) -> int:
|
20
|
+
"""
|
21
|
+
Computes the contract address in the Starknet network - a unique identifier of the contract.
|
22
|
+
|
23
|
+
:param class_hash: class hash of the contract
|
24
|
+
:param constructor_calldata: calldata for the contract constructor
|
25
|
+
:param salt: salt used to calculate contract address
|
26
|
+
:param deployer_address: address of the deployer (if not provided default 0 is used)
|
27
|
+
:return: Contract's address
|
28
|
+
"""
|
29
|
+
|
30
|
+
constructor_calldata_hash = compute_hash_on_elements(data=constructor_calldata)
|
31
|
+
raw_address = compute_hash_on_elements(
|
32
|
+
data=[
|
33
|
+
CONTRACT_ADDRESS_PREFIX,
|
34
|
+
deployer_address,
|
35
|
+
salt,
|
36
|
+
class_hash,
|
37
|
+
constructor_calldata_hash,
|
38
|
+
],
|
39
|
+
)
|
40
|
+
|
41
|
+
return raw_address % L2_ADDRESS_UPPER_BOUND
|
42
|
+
|
43
|
+
|
44
|
+
def get_checksum_address(address: str) -> str:
|
45
|
+
"""
|
46
|
+
Outputs formatted checksum address.
|
47
|
+
|
48
|
+
Follows implementation of starknet.js. It is not compatible with EIP55 as it treats hex string as encoded number,
|
49
|
+
instead of encoding it as ASCII string.
|
50
|
+
|
51
|
+
:param address: Address to encode
|
52
|
+
:return: Checksum address
|
53
|
+
"""
|
54
|
+
if not address.lower().startswith(HEX_PREFIX):
|
55
|
+
raise ValueError(f"{address} is not a valid hexadecimal address.")
|
56
|
+
|
57
|
+
int_address = int(address, 16)
|
58
|
+
string_address = address[2:].zfill(64)
|
59
|
+
|
60
|
+
address_in_bytes = encode_uint(int_address, get_bytes_length(int_address))
|
61
|
+
address_hash = _starknet_keccak(address_in_bytes)
|
62
|
+
|
63
|
+
result = "".join(
|
64
|
+
(
|
65
|
+
char.upper()
|
66
|
+
if char.isalpha() and (address_hash >> 256 - 4 * i - 1) & 1
|
67
|
+
else char
|
68
|
+
)
|
69
|
+
for i, char in enumerate(string_address)
|
70
|
+
)
|
71
|
+
|
72
|
+
return f"{HEX_PREFIX}{result}"
|
73
|
+
|
74
|
+
|
75
|
+
def is_checksum_address(address: str) -> bool:
|
76
|
+
"""
|
77
|
+
Checks if provided string is in a checksum address format.
|
78
|
+
"""
|
79
|
+
return get_checksum_address(address) == address
|
@@ -0,0 +1,111 @@
|
|
1
|
+
# File is copied from
|
2
|
+
# https://github.com/starkware-libs/cairo-lang/blob/v0.13.1/src/starkware/starknet/core/os/contract_class/compiled_class_hash_objects.py
|
3
|
+
|
4
|
+
import dataclasses
|
5
|
+
import itertools
|
6
|
+
from abc import ABC, abstractmethod
|
7
|
+
from typing import Any, List, Union
|
8
|
+
|
9
|
+
from poseidon_py.poseidon_hash import poseidon_hash_many
|
10
|
+
|
11
|
+
|
12
|
+
class BytecodeSegmentStructure(ABC):
|
13
|
+
"""
|
14
|
+
Represents the structure of the bytecode to allow loading it partially into the OS memory.
|
15
|
+
See the documentation of the OS function `bytecode_hash_node` in `compiled_class.cairo`
|
16
|
+
for more details.
|
17
|
+
"""
|
18
|
+
|
19
|
+
@abstractmethod
|
20
|
+
def hash(self) -> int:
|
21
|
+
"""
|
22
|
+
Computes the hash of the node.
|
23
|
+
"""
|
24
|
+
|
25
|
+
def bytecode_with_skipped_segments(self):
|
26
|
+
"""
|
27
|
+
Returns the bytecode of the node.
|
28
|
+
Skipped segments are replaced with [-1, -2, -2, -2, ...].
|
29
|
+
"""
|
30
|
+
res: List[int] = []
|
31
|
+
self.add_bytecode_with_skipped_segments(res)
|
32
|
+
return res
|
33
|
+
|
34
|
+
@abstractmethod
|
35
|
+
def add_bytecode_with_skipped_segments(self, data: List[int]):
|
36
|
+
"""
|
37
|
+
Same as bytecode_with_skipped_segments, but appends the result to the given list.
|
38
|
+
"""
|
39
|
+
|
40
|
+
|
41
|
+
@dataclasses.dataclass
|
42
|
+
class BytecodeLeaf(BytecodeSegmentStructure):
|
43
|
+
"""
|
44
|
+
Represents a leaf in the bytecode segment tree.
|
45
|
+
"""
|
46
|
+
|
47
|
+
data: List[int]
|
48
|
+
|
49
|
+
def hash(self) -> int:
|
50
|
+
return poseidon_hash_many(self.data)
|
51
|
+
|
52
|
+
def add_bytecode_with_skipped_segments(self, data: List[int]):
|
53
|
+
data.extend(self.data)
|
54
|
+
|
55
|
+
|
56
|
+
@dataclasses.dataclass
|
57
|
+
class BytecodeSegmentedNode(BytecodeSegmentStructure):
|
58
|
+
"""
|
59
|
+
Represents an internal node in the bytecode segment tree.
|
60
|
+
Each child can be loaded into memory or skipped.
|
61
|
+
"""
|
62
|
+
|
63
|
+
segments: List["BytecodeSegment"]
|
64
|
+
|
65
|
+
def hash(self) -> int:
|
66
|
+
return (
|
67
|
+
poseidon_hash_many(
|
68
|
+
itertools.chain( # pyright: ignore
|
69
|
+
*[
|
70
|
+
(node.segment_length, node.inner_structure.hash())
|
71
|
+
for node in self.segments
|
72
|
+
]
|
73
|
+
)
|
74
|
+
)
|
75
|
+
+ 1
|
76
|
+
)
|
77
|
+
|
78
|
+
def add_bytecode_with_skipped_segments(self, data: List[int]):
|
79
|
+
for segment in self.segments:
|
80
|
+
if segment.is_used:
|
81
|
+
segment.inner_structure.add_bytecode_with_skipped_segments(data)
|
82
|
+
else:
|
83
|
+
data.append(-1)
|
84
|
+
data.extend(-2 for _ in range(segment.segment_length - 1))
|
85
|
+
|
86
|
+
|
87
|
+
@dataclasses.dataclass
|
88
|
+
class BytecodeSegment:
|
89
|
+
"""
|
90
|
+
Represents a child of BytecodeSegmentedNode.
|
91
|
+
"""
|
92
|
+
|
93
|
+
# The length of the segment.
|
94
|
+
segment_length: int
|
95
|
+
# Should the segment (or part of it) be loaded to memory.
|
96
|
+
# In other words, is the segment used during the execution.
|
97
|
+
# Note that if is_used is False, the entire segment is not loaded to memory.
|
98
|
+
# If is_used is True, it is possible that part of the segment will be skipped (according
|
99
|
+
# to the "is_used" field of the child segments).
|
100
|
+
is_used: bool
|
101
|
+
# The inner structure of the segment.
|
102
|
+
inner_structure: BytecodeSegmentStructure
|
103
|
+
|
104
|
+
def __post_init__(self):
|
105
|
+
assert (
|
106
|
+
self.segment_length > 0
|
107
|
+
), f"Invalid segment length: {self.segment_length}."
|
108
|
+
|
109
|
+
|
110
|
+
# Represents a nested list of integers. E.g., [1, [2, [3], 4], 5, 6].
|
111
|
+
NestedIntList = Union[int, List[Any]]
|
@@ -0,0 +1,16 @@
|
|
1
|
+
from ..constants import (
|
2
|
+
DEFAULT_ENTRY_POINT_NAME,
|
3
|
+
DEFAULT_ENTRY_POINT_SELECTOR,
|
4
|
+
DEFAULT_L1_ENTRY_POINT_NAME,
|
5
|
+
)
|
6
|
+
from ..hash.utils import _starknet_keccak
|
7
|
+
|
8
|
+
|
9
|
+
def get_selector_from_name(func_name: str) -> int:
|
10
|
+
"""
|
11
|
+
Returns the selector of a contract's function name.
|
12
|
+
"""
|
13
|
+
if func_name in [DEFAULT_ENTRY_POINT_NAME, DEFAULT_L1_ENTRY_POINT_NAME]:
|
14
|
+
return DEFAULT_ENTRY_POINT_SELECTOR
|
15
|
+
|
16
|
+
return _starknet_keccak(data=func_name.encode("ascii"))
|
@@ -0,0 +1,12 @@
|
|
1
|
+
from functools import reduce
|
2
|
+
|
3
|
+
from constants import ADDR_BOUND
|
4
|
+
from hash.utils import _starknet_keccak, pedersen_hash
|
5
|
+
|
6
|
+
|
7
|
+
def get_storage_var_address(var_name: str, *args: int) -> int:
|
8
|
+
"""
|
9
|
+
Returns the storage address of a Starknet storage variable given its name and arguments.
|
10
|
+
"""
|
11
|
+
res = _starknet_keccak(var_name.encode("ascii"))
|
12
|
+
return reduce(pedersen_hash, args, res) % ADDR_BOUND
|
@@ -0,0 +1,78 @@
|
|
1
|
+
import functools
|
2
|
+
from typing import List, Optional, Sequence
|
3
|
+
|
4
|
+
from ... import keccak
|
5
|
+
|
6
|
+
from ..common import int_from_bytes
|
7
|
+
from ..constants import EC_ORDER
|
8
|
+
from ...starkware.crypto.signature import (
|
9
|
+
ECSignature,
|
10
|
+
private_to_stark_key,
|
11
|
+
sign
|
12
|
+
# verify
|
13
|
+
)
|
14
|
+
from ...starkware.crypto.fast_pedersen_hash import (
|
15
|
+
pedersen_hash
|
16
|
+
)
|
17
|
+
|
18
|
+
MASK_250 = 2**250 - 1
|
19
|
+
HEX_PREFIX = "0x"
|
20
|
+
|
21
|
+
|
22
|
+
def _starknet_keccak(data: bytes) -> int:
|
23
|
+
"""
|
24
|
+
A variant of eth-keccak that computes a value that fits in a Starknet field element.
|
25
|
+
"""
|
26
|
+
return int_from_bytes(keccak.SHA3(data)) & MASK_250
|
27
|
+
|
28
|
+
|
29
|
+
# def pedersen_hash(left: int, right: int) -> int:
|
30
|
+
# """
|
31
|
+
# One of two hash functions (along with _starknet_keccak) used throughout Starknet.
|
32
|
+
# """
|
33
|
+
# return cpp_hash(left, right)
|
34
|
+
|
35
|
+
|
36
|
+
def compute_hash_on_elements(data: Sequence) -> int:
|
37
|
+
"""
|
38
|
+
Computes a hash chain over the data, in the following order:
|
39
|
+
h(h(h(h(0, data[0]), data[1]), ...), data[n-1]), n).
|
40
|
+
|
41
|
+
The hash is initialized with 0 and ends with the data length appended.
|
42
|
+
The length is appended in order to avoid collisions of the following kind:
|
43
|
+
H([x,y,z]) = h(h(x,y),z) = H([w, z]) where w = h(x,y).
|
44
|
+
"""
|
45
|
+
return functools.reduce(pedersen_hash, [*data, len(data)], 0)
|
46
|
+
|
47
|
+
|
48
|
+
def message_signature(
|
49
|
+
msg_hash: int, priv_key: int, seed: Optional[int] = 32
|
50
|
+
) -> ECSignature:
|
51
|
+
"""
|
52
|
+
Signs the message with private key.
|
53
|
+
"""
|
54
|
+
return sign(msg_hash, priv_key, seed)
|
55
|
+
|
56
|
+
|
57
|
+
# def verify_message_signature(
|
58
|
+
# msg_hash: int, signature: List[int], public_key: int
|
59
|
+
# ) -> bool:
|
60
|
+
# """
|
61
|
+
# Verifies ECDSA signature of a given message hash with a given public key.
|
62
|
+
# Returns true if public_key signs the message.
|
63
|
+
# """
|
64
|
+
# sig_r, sig_s = signature
|
65
|
+
# # sig_w = pow(sig_s, -1, EC_ORDER)
|
66
|
+
# return verify(msg_hash=msg_hash, r=sig_r, s=sig_s, public_key=public_key)
|
67
|
+
|
68
|
+
|
69
|
+
def encode_uint(value: int, bytes_length: int = 32) -> bytes:
|
70
|
+
return value.to_bytes(bytes_length, byteorder="big")
|
71
|
+
|
72
|
+
|
73
|
+
def encode_uint_list(data: List[int]) -> bytes:
|
74
|
+
return b"".join(encode_uint(x) for x in data)
|
75
|
+
|
76
|
+
|
77
|
+
def get_bytes_length(value: int) -> int:
|
78
|
+
return (value.bit_length() + 7) // 8
|
File without changes
|
@@ -0,0 +1,45 @@
|
|
1
|
+
"""
|
2
|
+
TypedDict structures for TypedData
|
3
|
+
"""
|
4
|
+
|
5
|
+
from enum import Enum
|
6
|
+
from typing import Any, Dict, List, Optional, TypedDict
|
7
|
+
|
8
|
+
class Revision(Enum):
|
9
|
+
"""
|
10
|
+
Enum representing the revision of the specification to be used.
|
11
|
+
"""
|
12
|
+
|
13
|
+
V0 = 0
|
14
|
+
V1 = 1
|
15
|
+
|
16
|
+
|
17
|
+
class ParameterDict(TypedDict):
|
18
|
+
"""
|
19
|
+
TypedDict representing a Parameter object
|
20
|
+
"""
|
21
|
+
|
22
|
+
name: str
|
23
|
+
type: str
|
24
|
+
|
25
|
+
|
26
|
+
class StarkNetDomainDict(TypedDict):
|
27
|
+
"""
|
28
|
+
TypedDict representing a domain object (both StarkNetDomain, StarknetDomain).
|
29
|
+
"""
|
30
|
+
|
31
|
+
name: str
|
32
|
+
version: str
|
33
|
+
chainId: str
|
34
|
+
revision: Optional[Revision]
|
35
|
+
|
36
|
+
|
37
|
+
class TypedDataDict(TypedDict):
|
38
|
+
"""
|
39
|
+
TypedDict representing a TypedData object
|
40
|
+
"""
|
41
|
+
|
42
|
+
types: Dict[str, List[ParameterDict]]
|
43
|
+
primaryType: str
|
44
|
+
domain: StarkNetDomainDict
|
45
|
+
message: Dict[str, Any]
|