Merge branch 'master' into kvdb_split
This commit is contained in:
commit
5c220ab64b
336
Cargo.lock
generated
336
Cargo.lock
generated
@ -4,8 +4,8 @@ version = "0.1.0"
|
|||||||
dependencies = [
|
dependencies = [
|
||||||
"byteorder 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"byteorder 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"parity-wasm 0.14.5 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parity-wasm 0.14.5 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"vm 0.1.0",
|
"vm 0.1.0",
|
||||||
@ -374,7 +374,7 @@ dependencies = [
|
|||||||
"bloomable 0.1.0",
|
"bloomable 0.1.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethjson 0.1.0",
|
"ethjson 0.1.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -554,7 +554,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethash"
|
name = "ethash"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"crunchy 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
"crunchy 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"either 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"either 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -567,7 +567,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore"
|
name = "ethcore"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ansi_term 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ansi_term 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"bloomable 0.1.0",
|
"bloomable 0.1.0",
|
||||||
@ -577,24 +577,24 @@ dependencies = [
|
|||||||
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"common-types 0.1.0",
|
"common-types 0.1.0",
|
||||||
"crossbeam 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)",
|
"crossbeam 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethash 1.8.0",
|
"ethash 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bloom-journal 0.1.0",
|
"ethcore-bloom-journal 0.1.0",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-io 1.8.0",
|
"ethcore-io 1.9.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-ipc-nano 1.8.0",
|
"ethcore-ipc-nano 1.9.0",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"ethcore-stratum 1.8.0",
|
"ethcore-stratum 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethjson 0.1.0",
|
"ethjson 0.1.0",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
"ethstore 0.1.0",
|
"ethstore 0.1.0",
|
||||||
"evm 0.1.0",
|
"evm 0.1.0",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"hardware-wallet 1.8.0",
|
"hardware-wallet 1.9.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"hashdb 0.1.0",
|
"hashdb 0.1.0",
|
||||||
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -662,14 +662,14 @@ version = "0.1.0"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-devtools"
|
name = "ethcore-devtools"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"rand 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"rand 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-io"
|
name = "ethcore-io"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"crossbeam 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)",
|
"crossbeam 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -680,18 +680,18 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-ipc"
|
name = "ethcore-ipc"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"nanomsg 0.5.1 (git+https://github.com/paritytech/nanomsg.rs.git?branch=parity-1.7)",
|
"nanomsg 0.5.1 (git+https://github.com/paritytech/nanomsg.rs.git?branch=parity-1.7)",
|
||||||
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-ipc-codegen"
|
name = "ethcore-ipc-codegen"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"aster 0.41.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"aster 0.41.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"clippy 0.0.163 (registry+https://github.com/rust-lang/crates.io-index)",
|
"clippy 0.0.163 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -706,9 +706,9 @@ dependencies = [
|
|||||||
name = "ethcore-ipc-hypervisor"
|
name = "ethcore-ipc-hypervisor"
|
||||||
version = "1.2.0"
|
version = "1.2.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-ipc-nano 1.8.0",
|
"ethcore-ipc-nano 1.9.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"nanomsg 0.5.1 (git+https://github.com/paritytech/nanomsg.rs.git?branch=parity-1.7)",
|
"nanomsg 0.5.1 (git+https://github.com/paritytech/nanomsg.rs.git?branch=parity-1.7)",
|
||||||
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -717,9 +717,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-ipc-nano"
|
name = "ethcore-ipc-nano"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"lazy_static 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"lazy_static 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"nanomsg 0.5.1 (git+https://github.com/paritytech/nanomsg.rs.git?branch=parity-1.7)",
|
"nanomsg 0.5.1 (git+https://github.com/paritytech/nanomsg.rs.git?branch=parity-1.7)",
|
||||||
@ -730,11 +730,11 @@ name = "ethcore-ipc-tests"
|
|||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-ipc-nano 1.8.0",
|
"ethcore-ipc-nano 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"nanomsg 0.5.1 (git+https://github.com/paritytech/nanomsg.rs.git?branch=parity-1.7)",
|
"nanomsg 0.5.1 (git+https://github.com/paritytech/nanomsg.rs.git?branch=parity-1.7)",
|
||||||
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -742,18 +742,18 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-light"
|
name = "ethcore-light"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bincode 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"bincode 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-io 1.8.0",
|
"ethcore-io 1.9.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-network 1.8.0",
|
"ethcore-network 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"evm 0.1.0",
|
"evm 0.1.0",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
@ -780,7 +780,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-logger"
|
name = "ethcore-logger"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ansi_term 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ansi_term 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"arrayvec 0.3.23 (registry+https://github.com/rust-lang/crates.io-index)",
|
"arrayvec 0.3.23 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -795,17 +795,17 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-network"
|
name = "ethcore-network"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ansi_term 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ansi_term 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"bytes 0.4.5 (registry+https://github.com/rust-lang/crates.io-index)",
|
"bytes 0.4.5 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-io 1.8.0",
|
"ethcore-io 1.9.0",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethcrypto 0.1.0",
|
"ethcrypto 0.1.0",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
@ -832,15 +832,15 @@ version = "1.0.0"
|
|||||||
dependencies = [
|
dependencies = [
|
||||||
"byteorder 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"byteorder 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethabi 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ethabi 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-ipc-nano 1.8.0",
|
"ethcore-ipc-nano 1.9.0",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethcrypto 0.1.0",
|
"ethcrypto 0.1.0",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -867,16 +867,16 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-stratum"
|
name = "ethcore-stratum"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-ipc-nano 1.8.0",
|
"ethcore-ipc-nano 1.9.0",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"jsonrpc-core 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
"jsonrpc-core 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
||||||
"jsonrpc-macros 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
"jsonrpc-macros 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
||||||
@ -889,7 +889,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethcore-util"
|
name = "ethcore-util"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"elastic-array 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"elastic-array 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -898,8 +898,8 @@ dependencies = [
|
|||||||
"eth-secp256k1 0.5.6 (git+https://github.com/paritytech/rust-secp256k1)",
|
"eth-secp256k1 0.5.6 (git+https://github.com/paritytech/rust-secp256k1)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"hashdb 0.1.0",
|
"hashdb 0.1.0",
|
||||||
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -1011,21 +1011,21 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ethsync"
|
name = "ethsync"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-io 1.8.0",
|
"ethcore-io 1.9.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-ipc-nano 1.8.0",
|
"ethcore-ipc-nano 1.9.0",
|
||||||
"ethcore-light 1.8.0",
|
"ethcore-light 1.9.0",
|
||||||
"ethcore-network 1.8.0",
|
"ethcore-network 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -1051,10 +1051,10 @@ dependencies = [
|
|||||||
"byteorder 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"byteorder 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"common-types 0.1.0",
|
"common-types 0.1.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethjson 0.1.0",
|
"ethjson 0.1.0",
|
||||||
"evmjit 1.8.0",
|
"evmjit 1.9.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"heapsize 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"lazy_static 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"lazy_static 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -1071,10 +1071,10 @@ name = "evmbin"
|
|||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"docopt 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"docopt 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethjson 0.1.0",
|
"ethjson 0.1.0",
|
||||||
"evm 0.1.0",
|
"evm 0.1.0",
|
||||||
"panic_hook 0.1.0",
|
"panic_hook 0.1.0",
|
||||||
@ -1086,7 +1086,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "evmjit"
|
name = "evmjit"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"tiny-keccak 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"tiny-keccak 1.3.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
@ -1190,7 +1190,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "hardware-wallet"
|
name = "hardware-wallet"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
@ -1367,12 +1367,12 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ipc-common-types"
|
name = "ipc-common-types"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"semver 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -1540,7 +1540,7 @@ version = "0.1.0"
|
|||||||
dependencies = [
|
dependencies = [
|
||||||
"elastic-array 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"elastic-array 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"kvdb 0.1.0",
|
"kvdb 0.1.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -1692,7 +1692,7 @@ dependencies = [
|
|||||||
name = "migration"
|
name = "migration"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"kvdb 0.1.0",
|
"kvdb 0.1.0",
|
||||||
"kvdb-rocksdb 0.1.0",
|
"kvdb-rocksdb 0.1.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -1875,14 +1875,14 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "node-filter"
|
name = "node-filter"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-io 1.8.0",
|
"ethcore-io 1.9.0",
|
||||||
"ethcore-network 1.8.0",
|
"ethcore-network 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"kvdb-memorydb 0.1.0",
|
"kvdb-memorydb 0.1.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2091,23 +2091,23 @@ dependencies = [
|
|||||||
"daemonize 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"daemonize 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"docopt 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"docopt 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-io 1.8.0",
|
"ethcore-io 1.9.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-hypervisor 1.2.0",
|
"ethcore-ipc-hypervisor 1.2.0",
|
||||||
"ethcore-ipc-nano 1.8.0",
|
"ethcore-ipc-nano 1.9.0",
|
||||||
"ethcore-ipc-tests 0.1.0",
|
"ethcore-ipc-tests 0.1.0",
|
||||||
"ethcore-light 1.8.0",
|
"ethcore-light 1.9.0",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"ethcore-network 1.8.0",
|
"ethcore-network 1.9.0",
|
||||||
"ethcore-secretstore 1.0.0",
|
"ethcore-secretstore 1.0.0",
|
||||||
"ethcore-stratum 1.8.0",
|
"ethcore-stratum 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
"ethsync 1.8.0",
|
"ethsync 1.9.0",
|
||||||
"fdlimit 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"fdlimit 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"futures-cpupool 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures-cpupool 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2118,19 +2118,19 @@ dependencies = [
|
|||||||
"kvdb-rocksdb 0.1.0",
|
"kvdb-rocksdb 0.1.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"migration 0.1.0",
|
"migration 0.1.0",
|
||||||
"node-filter 1.8.0",
|
"node-filter 1.9.0",
|
||||||
"node-health 0.1.0",
|
"node-health 0.1.0",
|
||||||
"num_cpus 1.6.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"num_cpus 1.6.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"number_prefix 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)",
|
"number_prefix 0.2.7 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"panic_hook 0.1.0",
|
"panic_hook 0.1.0",
|
||||||
"parity-dapps 1.8.0",
|
"parity-dapps 1.9.0",
|
||||||
"parity-hash-fetch 1.8.0",
|
"parity-hash-fetch 1.9.0",
|
||||||
"parity-ipfs-api 1.8.0",
|
"parity-ipfs-api 1.9.0",
|
||||||
"parity-local-store 0.1.0",
|
"parity-local-store 0.1.0",
|
||||||
"parity-reactor 0.1.0",
|
"parity-reactor 0.1.0",
|
||||||
"parity-rpc 1.8.0",
|
"parity-rpc 1.9.0",
|
||||||
"parity-rpc-client 1.4.0",
|
"parity-rpc-client 1.4.0",
|
||||||
"parity-updater 1.8.0",
|
"parity-updater 1.9.0",
|
||||||
"parity-whisper 0.1.0",
|
"parity-whisper 0.1.0",
|
||||||
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"path 0.1.0",
|
"path 0.1.0",
|
||||||
@ -2153,15 +2153,15 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-dapps"
|
name = "parity-dapps"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"base32 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"base32 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"fetch 0.1.0",
|
"fetch 0.1.0",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"futures-cpupool 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures-cpupool 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2174,9 +2174,9 @@ dependencies = [
|
|||||||
"mime_guess 2.0.0-alpha.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"mime_guess 2.0.0-alpha.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"node-health 0.1.0",
|
"node-health 0.1.0",
|
||||||
"parity-dapps-glue 1.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parity-dapps-glue 1.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"parity-hash-fetch 1.8.0",
|
"parity-hash-fetch 1.9.0",
|
||||||
"parity-reactor 0.1.0",
|
"parity-reactor 0.1.0",
|
||||||
"parity-ui 1.8.0",
|
"parity-ui 1.9.0",
|
||||||
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"rand 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"rand 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"rustc-hex 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"rustc-hex 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2187,21 +2187,6 @@ dependencies = [
|
|||||||
"zip 0.1.19 (registry+https://github.com/rust-lang/crates.io-index)",
|
"zip 0.1.19 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "parity-dapps-glue"
|
|
||||||
version = "1.8.0"
|
|
||||||
dependencies = [
|
|
||||||
"aster 0.41.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"clippy 0.0.90 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"glob 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"mime_guess 2.0.0-alpha.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"quasi 0.32.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"quasi_codegen 0.32.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"quasi_macros 0.32.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"syntex 0.58.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
"syntex_syntax 0.58.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-dapps-glue"
|
name = "parity-dapps-glue"
|
||||||
version = "1.8.0"
|
version = "1.8.0"
|
||||||
@ -2216,14 +2201,29 @@ dependencies = [
|
|||||||
"syntex_syntax 0.58.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"syntex_syntax 0.58.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "parity-dapps-glue"
|
||||||
|
version = "1.9.0"
|
||||||
|
dependencies = [
|
||||||
|
"aster 0.41.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"clippy 0.0.90 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"glob 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"mime_guess 2.0.0-alpha.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"quasi 0.32.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"quasi_codegen 0.32.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"quasi_macros 0.32.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"syntex 0.58.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"syntex_syntax 0.58.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-hash-fetch"
|
name = "parity-hash-fetch"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethabi 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ethabi 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"fetch 0.1.0",
|
"fetch 0.1.0",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
@ -2239,13 +2239,13 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-ipfs-api"
|
name = "parity-ipfs-api"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cid 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"cid 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"jsonrpc-core 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
"jsonrpc-core 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
||||||
"jsonrpc-http-server 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
"jsonrpc-http-server 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
||||||
"multihash 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"multihash 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2257,9 +2257,9 @@ dependencies = [
|
|||||||
name = "parity-local-store"
|
name = "parity-local-store"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-io 1.8.0",
|
"ethcore-io 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
"kvdb 0.1.0",
|
"kvdb 0.1.0",
|
||||||
"kvdb-memorydb 0.1.0",
|
"kvdb-memorydb 0.1.0",
|
||||||
@ -2275,7 +2275,7 @@ name = "parity-machine"
|
|||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -2288,30 +2288,30 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-rpc"
|
name = "parity-rpc"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ansi_term 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ansi_term 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"cid 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"cid 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
"clippy 0.0.103 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethash 1.8.0",
|
"ethash 1.9.0",
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-devtools 1.8.0",
|
"ethcore-devtools 1.9.0",
|
||||||
"ethcore-io 1.8.0",
|
"ethcore-io 1.9.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-light 1.8.0",
|
"ethcore-light 1.9.0",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"ethcore-network 1.8.0",
|
"ethcore-network 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethcrypto 0.1.0",
|
"ethcrypto 0.1.0",
|
||||||
"ethjson 0.1.0",
|
"ethjson 0.1.0",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
"ethstore 0.1.0",
|
"ethstore 0.1.0",
|
||||||
"ethsync 1.8.0",
|
"ethsync 1.9.0",
|
||||||
"fetch 0.1.0",
|
"fetch 0.1.0",
|
||||||
"futures-cpupool 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures-cpupool 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"hardware-wallet 1.8.0",
|
"hardware-wallet 1.9.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"itertools 0.5.10 (registry+https://github.com/rust-lang/crates.io-index)",
|
"itertools 0.5.10 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"jsonrpc-core 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
"jsonrpc-core 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
||||||
@ -2327,7 +2327,7 @@ dependencies = [
|
|||||||
"node-health 0.1.0",
|
"node-health 0.1.0",
|
||||||
"order-stat 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"order-stat 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"parity-reactor 0.1.0",
|
"parity-reactor 0.1.0",
|
||||||
"parity-updater 1.8.0",
|
"parity-updater 1.9.0",
|
||||||
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"pretty_assertions 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"pretty_assertions 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"rand 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"rand 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2355,7 +2355,7 @@ dependencies = [
|
|||||||
"jsonrpc-ws-server 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
"jsonrpc-ws-server 8.0.0 (git+https://github.com/paritytech/jsonrpc.git?branch=parity-1.8)",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"matches 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
"matches 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"parity-rpc 1.8.0",
|
"parity-rpc 1.9.0",
|
||||||
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"serde 1.0.15 (registry+https://github.com/rust-lang/crates.io-index)",
|
"serde 1.0.15 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"serde_json 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
"serde_json 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2381,16 +2381,16 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-ui"
|
name = "parity-ui"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"parity-ui-dev 1.8.0",
|
"parity-ui-dev 1.9.0",
|
||||||
"parity-ui-precompiled 1.4.0 (git+https://github.com/paritytech/js-precompiled.git)",
|
"parity-ui-precompiled 1.4.0 (git+https://github.com/paritytech/js-precompiled.git)",
|
||||||
"rustc_version 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)",
|
"rustc_version 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-ui-dev"
|
name = "parity-ui-dev"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"parity-dapps-glue 1.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parity-dapps-glue 1.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
@ -2398,27 +2398,27 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-ui-precompiled"
|
name = "parity-ui-precompiled"
|
||||||
version = "1.4.0"
|
version = "1.4.0"
|
||||||
source = "git+https://github.com/paritytech/js-precompiled.git#87ee470b6f0b4a39ad6cefac21cc5b112ba0348d"
|
source = "git+https://github.com/paritytech/js-precompiled.git#4b77a23c3e55aed45725f43cd2a499676375b995"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"parity-dapps-glue 1.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parity-dapps-glue 1.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "parity-updater"
|
name = "parity-updater"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ethabi 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ethabi 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore 1.8.0",
|
"ethcore 1.9.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-ipc 1.8.0",
|
"ethcore-ipc 1.9.0",
|
||||||
"ethcore-ipc-codegen 1.8.0",
|
"ethcore-ipc-codegen 1.9.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethsync 1.8.0",
|
"ethsync 1.9.0",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ipc-common-types 1.8.0",
|
"ipc-common-types 1.9.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"parity-hash-fetch 1.8.0",
|
"parity-hash-fetch 1.9.0",
|
||||||
"parity-reactor 0.1.0",
|
"parity-reactor 0.1.0",
|
||||||
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"parking_lot 0.4.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"path 0.1.0",
|
"path 0.1.0",
|
||||||
@ -2442,7 +2442,7 @@ dependencies = [
|
|||||||
"bitflags 0.9.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"bitflags 0.9.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"byteorder 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"byteorder 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-network 1.8.0",
|
"ethcore-network 1.9.0",
|
||||||
"ethcrypto 0.1.0",
|
"ethcrypto 0.1.0",
|
||||||
"ethkey 0.2.0",
|
"ethkey 0.2.0",
|
||||||
"hex 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"hex 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2506,7 +2506,7 @@ dependencies = [
|
|||||||
"elastic-array 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"elastic-array 0.9.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-logger 1.8.0",
|
"ethcore-logger 1.9.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"hashdb 0.1.0",
|
"hashdb 0.1.0",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
@ -2875,9 +2875,9 @@ name = "rpc-cli"
|
|||||||
version = "1.4.0"
|
version = "1.4.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bigint 4.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"bigint 4.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
"futures 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"parity-rpc 1.8.0",
|
"parity-rpc 1.9.0",
|
||||||
"parity-rpc-client 1.4.0",
|
"parity-rpc-client 1.4.0",
|
||||||
"rpassword 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"rpassword 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
@ -3591,9 +3591,9 @@ dependencies = [
|
|||||||
"common-types 0.1.0",
|
"common-types 0.1.0",
|
||||||
"ethcore-bigint 0.1.3",
|
"ethcore-bigint 0.1.3",
|
||||||
"ethcore-bytes 0.1.0",
|
"ethcore-bytes 0.1.0",
|
||||||
"ethcore-util 1.8.0",
|
"ethcore-util 1.9.0",
|
||||||
"ethjson 0.1.0",
|
"ethjson 0.1.0",
|
||||||
"evmjit 1.8.0",
|
"evmjit 1.9.0",
|
||||||
"hash 0.1.0",
|
"hash 0.1.0",
|
||||||
"lazy_static 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"lazy_static 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
"log 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Parity Dapps crate"
|
description = "Parity Dapps crate"
|
||||||
name = "parity-dapps"
|
name = "parity-dapps"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Base Package for all Parity built-in dapps"
|
description = "Base Package for all Parity built-in dapps"
|
||||||
name = "parity-dapps-glue"
|
name = "parity-dapps-glue"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
@ -3,7 +3,7 @@ description = "Ethcore Parity UI"
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "parity-ui"
|
name = "parity-ui"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
|
@ -3,7 +3,7 @@ description = "Ethcore development/test/build tools"
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "ethcore-devtools"
|
name = "ethcore-devtools"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "ethash"
|
name = "ethash"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[lib]
|
[lib]
|
||||||
|
@ -3,7 +3,7 @@ description = "Ethcore library"
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "ethcore"
|
name = "ethcore"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
|
||||||
|
@ -574,7 +574,7 @@ impl<Cost: CostType> Interpreter<Cost> {
|
|||||||
let source_offset = stack.peek(1);
|
let source_offset = stack.peek(1);
|
||||||
let size = stack.peek(2);
|
let size = stack.peek(2);
|
||||||
let return_data_len = U256::from(self.return_data.len());
|
let return_data_len = U256::from(self.return_data.len());
|
||||||
if source_offset.overflow_add(*size).0 > return_data_len {
|
if source_offset.saturating_add(*size) > return_data_len {
|
||||||
return Err(vm::Error::OutOfBounds);
|
return Err(vm::Error::OutOfBounds);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -940,4 +940,25 @@ mod tests {
|
|||||||
assert_eq!(ext.calls.len(), 1);
|
assert_eq!(ext.calls.len(), 1);
|
||||||
assert_eq!(gas_left, 248_212.into());
|
assert_eq!(gas_left, 248_212.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn should_not_overflow_returndata() {
|
||||||
|
let code = "6001600160000360003e00".from_hex().unwrap();
|
||||||
|
|
||||||
|
let mut params = ActionParams::default();
|
||||||
|
params.address = 5.into();
|
||||||
|
params.gas = 300_000.into();
|
||||||
|
params.gas_price = 1.into();
|
||||||
|
params.code = Some(Arc::new(code));
|
||||||
|
let mut ext = FakeExt::new_byzantium();
|
||||||
|
ext.balances.insert(5.into(), 1_000_000_000.into());
|
||||||
|
ext.tracing = true;
|
||||||
|
|
||||||
|
let err = {
|
||||||
|
let mut vm = Factory::new(VMType::Interpreter, 1).create(params.gas);
|
||||||
|
test_finalize(vm.exec(params, &mut ext)).err().unwrap()
|
||||||
|
};
|
||||||
|
|
||||||
|
assert_eq!(err, ::vm::Error::OutOfBounds);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@ description = "Parity Light Client Implementation"
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "ethcore-light"
|
name = "ethcore-light"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@ description = "Parity smart network connections"
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "node-filter"
|
name = "node-filter"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
@ -988,9 +988,11 @@ impl Client {
|
|||||||
|
|
||||||
/// Tick the client.
|
/// Tick the client.
|
||||||
// TODO: manage by real events.
|
// TODO: manage by real events.
|
||||||
pub fn tick(&self) {
|
pub fn tick(&self, prevent_sleep: bool) {
|
||||||
self.check_garbage();
|
self.check_garbage();
|
||||||
self.check_snooze();
|
if !prevent_sleep {
|
||||||
|
self.check_snooze();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_garbage(&self) {
|
fn check_garbage(&self) {
|
||||||
@ -1098,7 +1100,7 @@ impl Client {
|
|||||||
if !self.liveness.load(AtomicOrdering::Relaxed) {
|
if !self.liveness.load(AtomicOrdering::Relaxed) {
|
||||||
self.liveness.store(true, AtomicOrdering::Relaxed);
|
self.liveness.store(true, AtomicOrdering::Relaxed);
|
||||||
self.notify(|n| n.start());
|
self.notify(|n| n.start());
|
||||||
trace!(target: "mode", "wake_up: Waking.");
|
info!(target: "mode", "wake_up: Waking.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1108,11 +1110,11 @@ impl Client {
|
|||||||
if self.queue_info().total_queue_size() <= MAX_QUEUE_SIZE_TO_SLEEP_ON {
|
if self.queue_info().total_queue_size() <= MAX_QUEUE_SIZE_TO_SLEEP_ON {
|
||||||
self.liveness.store(false, AtomicOrdering::Relaxed);
|
self.liveness.store(false, AtomicOrdering::Relaxed);
|
||||||
self.notify(|n| n.stop());
|
self.notify(|n| n.stop());
|
||||||
trace!(target: "mode", "sleep: Sleeping.");
|
info!(target: "mode", "sleep: Sleeping.");
|
||||||
} else {
|
} else {
|
||||||
trace!(target: "mode", "sleep: Cannot sleep - syncing ongoing.");
|
info!(target: "mode", "sleep: Cannot sleep - syncing ongoing.");
|
||||||
// TODO: Consider uncommenting.
|
// TODO: Consider uncommenting.
|
||||||
//*self.last_activity.lock() = Some(Instant::now());
|
//(*self.sleep_state.lock()).last_activity = Some(Instant::now());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,7 +28,7 @@ use error::*;
|
|||||||
use client::{Client, ClientConfig, ChainNotify};
|
use client::{Client, ClientConfig, ChainNotify};
|
||||||
use miner::Miner;
|
use miner::Miner;
|
||||||
|
|
||||||
use snapshot::ManifestData;
|
use snapshot::{ManifestData, RestorationStatus};
|
||||||
use snapshot::service::{Service as SnapshotService, ServiceParams as SnapServiceParams};
|
use snapshot::service::{Service as SnapshotService, ServiceParams as SnapServiceParams};
|
||||||
use std::sync::atomic::AtomicBool;
|
use std::sync::atomic::AtomicBool;
|
||||||
use ansi_term::Colour;
|
use ansi_term::Colour;
|
||||||
@ -181,7 +181,11 @@ impl IoHandler<ClientIoMessage> for ClientIoHandler {
|
|||||||
|
|
||||||
fn timeout(&self, _io: &IoContext<ClientIoMessage>, timer: TimerToken) {
|
fn timeout(&self, _io: &IoContext<ClientIoMessage>, timer: TimerToken) {
|
||||||
match timer {
|
match timer {
|
||||||
CLIENT_TICK_TIMER => self.client.tick(),
|
CLIENT_TICK_TIMER => {
|
||||||
|
use snapshot::SnapshotService;
|
||||||
|
let snapshot_restoration = if let RestorationStatus::Ongoing{..} = self.snapshot.status() { true } else { false };
|
||||||
|
self.client.tick(snapshot_restoration)
|
||||||
|
},
|
||||||
SNAPSHOT_TICK_TIMER => self.snapshot.tick(),
|
SNAPSHOT_TICK_TIMER => self.snapshot.tick(),
|
||||||
_ => warn!("IO service triggered unregistered timer '{}'", timer),
|
_ => warn!("IO service triggered unregistered timer '{}'", timer),
|
||||||
}
|
}
|
||||||
|
@ -195,7 +195,7 @@ fn imports_block_sequence() {
|
|||||||
#[test]
|
#[test]
|
||||||
fn can_collect_garbage() {
|
fn can_collect_garbage() {
|
||||||
let client = generate_dummy_client(100);
|
let client = generate_dummy_client(100);
|
||||||
client.tick();
|
client.tick(true);
|
||||||
assert!(client.blockchain_cache_info().blocks < 100 * 1024);
|
assert!(client.blockchain_cache_info().blocks < 100 * 1024);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -80,6 +80,12 @@ impl FakeExt {
|
|||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
FakeExt::default()
|
FakeExt::default()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn new_byzantium() -> Self {
|
||||||
|
let mut ext = FakeExt::default();
|
||||||
|
ext.schedule = Schedule::new_byzantium();
|
||||||
|
ext
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Ext for FakeExt {
|
impl Ext for FakeExt {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "evmjit"
|
name = "evmjit"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[lib]
|
[lib]
|
||||||
|
@ -3,7 +3,7 @@ description = "Fetching hash-addressed content."
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "parity-hash-fetch"
|
name = "parity-hash-fetch"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
@ -3,7 +3,7 @@ description = "Hardware wallet support."
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "hardware-wallet"
|
name = "hardware-wallet"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Types that implement IPC and are common to multiple modules."
|
description = "Types that implement IPC and are common to multiple modules."
|
||||||
name = "ipc-common-types"
|
name = "ipc-common-types"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "ethcore-ipc-codegen"
|
name = "ethcore-ipc-codegen"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
description = "Macros to auto-generate implementations for ipc call"
|
description = "Macros to auto-generate implementations for ipc call"
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "ethcore-ipc-nano"
|
name = "ethcore-ipc-nano"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "ethcore-ipc"
|
name = "ethcore-ipc"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Parity IPFS-compatible API"
|
description = "Parity IPFS-compatible API"
|
||||||
name = "parity-ipfs-api"
|
name = "parity-ipfs-api"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Parity built-in dapps."
|
description = "Parity built-in dapps."
|
||||||
name = "parity-ui-dev"
|
name = "parity-ui-dev"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
14
js/package-lock.json
generated
14
js/package-lock.json
generated
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "parity.js",
|
"name": "parity.js",
|
||||||
"version": "1.8.30",
|
"version": "1.8.36",
|
||||||
"lockfileVersion": 1,
|
"lockfileVersion": 1,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
@ -428,7 +428,7 @@
|
|||||||
"glob": {
|
"glob": {
|
||||||
"version": "7.1.2",
|
"version": "7.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
|
||||||
"integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==",
|
"integrity": "sha1-wZyd+aAocC1nhhI4SmVSQExjbRU=",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"fs.realpath": "1.0.0",
|
"fs.realpath": "1.0.0",
|
||||||
@ -716,7 +716,7 @@
|
|||||||
"glob": {
|
"glob": {
|
||||||
"version": "7.1.2",
|
"version": "7.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
|
||||||
"integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==",
|
"integrity": "sha1-wZyd+aAocC1nhhI4SmVSQExjbRU=",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"fs.realpath": "1.0.0",
|
"fs.realpath": "1.0.0",
|
||||||
@ -4140,7 +4140,7 @@
|
|||||||
"glob": {
|
"glob": {
|
||||||
"version": "7.1.2",
|
"version": "7.1.2",
|
||||||
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
|
"resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
|
||||||
"integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==",
|
"integrity": "sha1-wZyd+aAocC1nhhI4SmVSQExjbRU=",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"fs.realpath": "1.0.0",
|
"fs.realpath": "1.0.0",
|
||||||
@ -11654,7 +11654,7 @@
|
|||||||
"string-width": {
|
"string-width": {
|
||||||
"version": "2.1.1",
|
"version": "2.1.1",
|
||||||
"resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
|
"resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
|
||||||
"integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==",
|
"integrity": "sha1-q5Pyeo3BPSjKyBXEYhQ6bZASrp4=",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"is-fullwidth-code-point": "2.0.0",
|
"is-fullwidth-code-point": "2.0.0",
|
||||||
@ -12611,7 +12611,7 @@
|
|||||||
"async": {
|
"async": {
|
||||||
"version": "2.5.0",
|
"version": "2.5.0",
|
||||||
"resolved": "https://registry.npmjs.org/async/-/async-2.5.0.tgz",
|
"resolved": "https://registry.npmjs.org/async/-/async-2.5.0.tgz",
|
||||||
"integrity": "sha512-e+lJAJeNWuPCNyxZKOBdaJGyLGHugXVQtrAwtuAe2vhxTYxFTKE73p8JuTmdH0qdQZtDvI4dhJwjZc5zsfIsYw==",
|
"integrity": "sha1-hDGQ/WtzV6C54clW7d3V7IRitU0=",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"lodash": "4.17.2"
|
"lodash": "4.17.2"
|
||||||
@ -13016,7 +13016,7 @@
|
|||||||
"commander": {
|
"commander": {
|
||||||
"version": "2.11.0",
|
"version": "2.11.0",
|
||||||
"resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz",
|
"resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz",
|
||||||
"integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ=="
|
"integrity": "sha1-FXFS/R56bI2YpbcVzzdt+SgARWM="
|
||||||
},
|
},
|
||||||
"detect-indent": {
|
"detect-indent": {
|
||||||
"version": "5.0.0",
|
"version": "5.0.0",
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "parity.js",
|
"name": "parity.js",
|
||||||
"version": "1.8.30",
|
"version": "1.8.36",
|
||||||
"main": "release/index.js",
|
"main": "release/index.js",
|
||||||
"jsnext:main": "src/index.js",
|
"jsnext:main": "src/index.js",
|
||||||
"author": "Parity Team <admin@parity.io>",
|
"author": "Parity Team <admin@parity.io>",
|
||||||
|
@ -1 +1 @@
|
|||||||
// test script 10
|
// test script 11
|
||||||
|
@ -47,13 +47,6 @@ export default class Api extends EventEmitter {
|
|||||||
this._trace = new Trace(transport);
|
this._trace = new Trace(transport);
|
||||||
this._web3 = new Web3(transport);
|
this._web3 = new Web3(transport);
|
||||||
|
|
||||||
if (isFunction(transport.subscribe)) {
|
|
||||||
this._pubsub = new Pubsub(transport);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (allowSubscriptions) {
|
|
||||||
this._subscriptions = new Subscriptions(this);
|
|
||||||
}
|
|
||||||
// Doing a request here in test env would cause an error
|
// Doing a request here in test env would cause an error
|
||||||
if (LocalAccountsMiddleware && process.env.NODE_ENV !== 'test') {
|
if (LocalAccountsMiddleware && process.env.NODE_ENV !== 'test') {
|
||||||
const middleware = this.parity
|
const middleware = this.parity
|
||||||
@ -69,6 +62,14 @@ export default class Api extends EventEmitter {
|
|||||||
|
|
||||||
transport.addMiddleware(middleware);
|
transport.addMiddleware(middleware);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isFunction(transport.subscribe)) {
|
||||||
|
this._pubsub = new Pubsub(transport);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (allowSubscriptions) {
|
||||||
|
this._subscriptions = new Subscriptions(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
get isPubSub () {
|
get isPubSub () {
|
||||||
|
@ -18,11 +18,12 @@ import Account from './account';
|
|||||||
import localStore from 'store';
|
import localStore from 'store';
|
||||||
import { debounce } from 'lodash';
|
import { debounce } from 'lodash';
|
||||||
import { decryptPrivateKey } from '../ethkey';
|
import { decryptPrivateKey } from '../ethkey';
|
||||||
|
import EventEmitter from 'eventemitter3';
|
||||||
|
|
||||||
const NULL_ADDRESS = '0x0000000000000000000000000000000000000000';
|
const NULL_ADDRESS = '0x0000000000000000000000000000000000000000';
|
||||||
const LS_STORE_KEY = '_parity::localAccounts';
|
const LS_STORE_KEY = '_parity::localAccounts';
|
||||||
|
|
||||||
export default class Accounts {
|
export default class Accounts extends EventEmitter {
|
||||||
persist = debounce(() => {
|
persist = debounce(() => {
|
||||||
this._lastState = JSON.stringify(this);
|
this._lastState = JSON.stringify(this);
|
||||||
|
|
||||||
@ -30,6 +31,8 @@ export default class Accounts {
|
|||||||
}, 100);
|
}, 100);
|
||||||
|
|
||||||
constructor (data = localStore.get(LS_STORE_KEY) || {}) {
|
constructor (data = localStore.get(LS_STORE_KEY) || {}) {
|
||||||
|
super();
|
||||||
|
|
||||||
this._lastState = JSON.stringify(data);
|
this._lastState = JSON.stringify(data);
|
||||||
|
|
||||||
window.addEventListener('storage', ({ key, newValue }) => {
|
window.addEventListener('storage', ({ key, newValue }) => {
|
||||||
@ -130,6 +133,8 @@ export default class Accounts {
|
|||||||
set dappsDefaultAddress (value) {
|
set dappsDefaultAddress (value) {
|
||||||
this._dappsDefaultAddress = value.toLowerCase();
|
this._dappsDefaultAddress = value.toLowerCase();
|
||||||
|
|
||||||
|
this.emit('dappsDefaultAddressChange', this._dappsDefaultAddress);
|
||||||
|
|
||||||
this.persist();
|
this.persist();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,7 +26,9 @@ export default class LocalAccountsMiddleware extends Middleware {
|
|||||||
constructor (transport) {
|
constructor (transport) {
|
||||||
super(transport);
|
super(transport);
|
||||||
|
|
||||||
|
const NOOP = () => {};
|
||||||
const register = this.register.bind(this);
|
const register = this.register.bind(this);
|
||||||
|
const registerSubscribe = this.registerSubscribe.bind(this);
|
||||||
|
|
||||||
register('eth_accounts', () => {
|
register('eth_accounts', () => {
|
||||||
return accounts.accountAddresses();
|
return accounts.accountAddresses();
|
||||||
@ -76,6 +78,14 @@ export default class LocalAccountsMiddleware extends Middleware {
|
|||||||
return accounts.dappsDefaultAddress;
|
return accounts.dappsDefaultAddress;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
registerSubscribe('parity_defaultAccount', (_, callback) => {
|
||||||
|
callback(null, accounts.dappsDefaultAddress);
|
||||||
|
|
||||||
|
accounts.on('dappsDefaultAddressChange', (address) => {
|
||||||
|
callback(null, accounts.dappsDefaultAddress);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
register('parity_exportAccount', ([address, password]) => {
|
register('parity_exportAccount', ([address, password]) => {
|
||||||
const account = accounts.get(address);
|
const account = accounts.get(address);
|
||||||
|
|
||||||
@ -109,6 +119,8 @@ export default class LocalAccountsMiddleware extends Middleware {
|
|||||||
return {};
|
return {};
|
||||||
});
|
});
|
||||||
|
|
||||||
|
registerSubscribe('parity_hardwareAccountsInfo', NOOP);
|
||||||
|
|
||||||
register('parity_newAccountFromPhrase', ([phrase, password]) => {
|
register('parity_newAccountFromPhrase', ([phrase, password]) => {
|
||||||
return phraseToWallet(phrase)
|
return phraseToWallet(phrase)
|
||||||
.then((wallet) => {
|
.then((wallet) => {
|
||||||
@ -278,5 +290,15 @@ export default class LocalAccountsMiddleware extends Middleware {
|
|||||||
register('signer_requestsToConfirm', () => {
|
register('signer_requestsToConfirm', () => {
|
||||||
return transactions.requestsToConfirm();
|
return transactions.requestsToConfirm();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
registerSubscribe('signer_subscribePending', (_, callback) => {
|
||||||
|
callback(null, transactions.requestsToConfirm());
|
||||||
|
|
||||||
|
transactions.on('update', () => {
|
||||||
|
callback(null, transactions.requestsToConfirm());
|
||||||
|
});
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,14 +16,17 @@
|
|||||||
|
|
||||||
import { toHex } from '../util/format';
|
import { toHex } from '../util/format';
|
||||||
import { TransportError } from '../transport';
|
import { TransportError } from '../transport';
|
||||||
|
import EventEmitter from 'eventemitter3';
|
||||||
|
|
||||||
const AWAITING = Symbol('awaiting');
|
const AWAITING = Symbol('awaiting');
|
||||||
const LOCKED = Symbol('locked');
|
const LOCKED = Symbol('locked');
|
||||||
const CONFIRMED = Symbol('confirmed');
|
const CONFIRMED = Symbol('confirmed');
|
||||||
const REJECTED = Symbol('rejected');
|
const REJECTED = Symbol('rejected');
|
||||||
|
|
||||||
class Transactions {
|
class Transactions extends EventEmitter {
|
||||||
constructor () {
|
constructor () {
|
||||||
|
super();
|
||||||
|
|
||||||
this.reset();
|
this.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -45,6 +48,8 @@ class Transactions {
|
|||||||
transaction: tx
|
transaction: tx
|
||||||
};
|
};
|
||||||
|
|
||||||
|
this.emit('update');
|
||||||
|
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -66,6 +71,8 @@ class Transactions {
|
|||||||
}
|
}
|
||||||
|
|
||||||
state.status = LOCKED;
|
state.status = LOCKED;
|
||||||
|
|
||||||
|
this.emit('update');
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock (id) {
|
unlock (id) {
|
||||||
@ -76,6 +83,8 @@ class Transactions {
|
|||||||
}
|
}
|
||||||
|
|
||||||
state.status = AWAITING;
|
state.status = AWAITING;
|
||||||
|
|
||||||
|
this.emit('update');
|
||||||
}
|
}
|
||||||
|
|
||||||
hash (id) {
|
hash (id) {
|
||||||
@ -107,6 +116,8 @@ class Transactions {
|
|||||||
|
|
||||||
state.hash = hash;
|
state.hash = hash;
|
||||||
state.status = CONFIRMED;
|
state.status = CONFIRMED;
|
||||||
|
|
||||||
|
this.emit('update');
|
||||||
}
|
}
|
||||||
|
|
||||||
reject (id) {
|
reject (id) {
|
||||||
@ -118,6 +129,8 @@ class Transactions {
|
|||||||
|
|
||||||
state.status = REJECTED;
|
state.status = REJECTED;
|
||||||
|
|
||||||
|
this.emit('update');
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ import PubsubBase from '../pubsubBase';
|
|||||||
|
|
||||||
import { outSignerRequest } from '../../format/output';
|
import { outSignerRequest } from '../../format/output';
|
||||||
|
|
||||||
export default class Net extends PubsubBase {
|
export default class Signer extends PubsubBase {
|
||||||
constructor (transport) {
|
constructor (transport) {
|
||||||
super(transport);
|
super(transport);
|
||||||
this._api = {
|
this._api = {
|
||||||
|
@ -38,26 +38,32 @@ export default class Signer {
|
|||||||
start () {
|
start () {
|
||||||
this._started = true;
|
this._started = true;
|
||||||
|
|
||||||
if (this._api.isPubSub) {
|
return this
|
||||||
const subscription = this._api.pubsub
|
._api
|
||||||
.subscribeAndGetResult(
|
.transport
|
||||||
callback => this._api.pubsub.signer.pendingRequests(callback),
|
.ready
|
||||||
requests => {
|
.then(() => {
|
||||||
this.updateSubscriptions(requests);
|
if (this._api.isPubSub) {
|
||||||
return requests;
|
const subscription = this._api.pubsub
|
||||||
}
|
.subscribeAndGetResult(
|
||||||
);
|
callback => this._api.pubsub.signer.pendingRequests(callback),
|
||||||
|
requests => {
|
||||||
|
this.updateSubscriptions(requests);
|
||||||
|
return requests;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
return Promise.all([
|
return Promise.all([
|
||||||
this._listRequests(false),
|
this._listRequests(false),
|
||||||
subscription
|
subscription
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return Promise.all([
|
return Promise.all([
|
||||||
this._listRequests(true),
|
this._listRequests(true),
|
||||||
this._loggingSubscribe()
|
this._loggingSubscribe()
|
||||||
]);
|
]);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
updateSubscriptions (requests) {
|
updateSubscriptions (requests) {
|
||||||
|
@ -31,6 +31,10 @@ export default class JsonRpcBase extends EventEmitter {
|
|||||||
this._middlewareList = Promise.resolve([]);
|
this._middlewareList = Promise.resolve([]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get ready () {
|
||||||
|
return this._middlewareList.then(() => true);
|
||||||
|
}
|
||||||
|
|
||||||
encode (method, params) {
|
encode (method, params) {
|
||||||
const json = JSON.stringify({
|
const json = JSON.stringify({
|
||||||
jsonrpc: '2.0',
|
jsonrpc: '2.0',
|
||||||
|
@ -17,7 +17,20 @@
|
|||||||
export default class Middleware {
|
export default class Middleware {
|
||||||
constructor (transport) {
|
constructor (transport) {
|
||||||
this._transport = transport;
|
this._transport = transport;
|
||||||
|
this._subscribe = transport.subscribe;
|
||||||
|
|
||||||
|
transport.subscribe = this.handleSubscribe.bind(this);
|
||||||
|
|
||||||
this._handlers = {};
|
this._handlers = {};
|
||||||
|
this._subHandlers = {};
|
||||||
|
}
|
||||||
|
|
||||||
|
registerSubscribe (method, handler) {
|
||||||
|
if (method in this._subHandlers) {
|
||||||
|
throw new Error(`${method} is already defined in the middleware!`);
|
||||||
|
}
|
||||||
|
|
||||||
|
this._subHandlers[method] = handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
register (method, handler) {
|
register (method, handler) {
|
||||||
@ -28,10 +41,24 @@ export default class Middleware {
|
|||||||
this._handlers[method] = handler;
|
this._handlers[method] = handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
handleSubscribe (api, callback, event) {
|
||||||
|
// Don't ask
|
||||||
|
const method = api.subscribe ? api.subscribe : event[0];
|
||||||
|
const params = event.length === 2 ? event[1] : event;
|
||||||
|
|
||||||
|
const handler = this._subHandlers[method];
|
||||||
|
|
||||||
|
if (handler) {
|
||||||
|
return handler(params, callback);
|
||||||
|
}
|
||||||
|
|
||||||
|
this._subscribe.call(this._transport, api, callback, event);
|
||||||
|
}
|
||||||
|
|
||||||
handle (method, params) {
|
handle (method, params) {
|
||||||
const handler = this._handlers[method];
|
const handler = this._handlers[method];
|
||||||
|
|
||||||
if (handler != null) {
|
if (handler) {
|
||||||
return handler(params);
|
return handler(params);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,3 +29,4 @@ export signaturereg from './signaturereg.json';
|
|||||||
export smsverification from './sms-verification.json';
|
export smsverification from './sms-verification.json';
|
||||||
export tokenreg from './tokenreg.json';
|
export tokenreg from './tokenreg.json';
|
||||||
export foundationWallet from './foundation-multisig-wallet.json';
|
export foundationWallet from './foundation-multisig-wallet.json';
|
||||||
|
export vouchfor from './vouchfor.json';
|
||||||
|
1
js/src/contracts/abi/vouchfor.json
Normal file
1
js/src/contracts/abi/vouchfor.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
[{"constant":true,"inputs":[],"name":"certifier","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_what","type":"bytes32"}],"name":"vouch","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_what","type":"bytes32"},{"name":"_index","type":"uint256"}],"name":"vouched","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_what","type":"bytes32"},{"name":"_index","type":"uint256"}],"name":"unvouch","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"","type":"bytes32"},{"name":"","type":"uint256"}],"name":"vouchers","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"name":"_certifier","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"name":"who","type":"address"},{"indexed":false,"name":"what","type":"bytes32"}],"name":"Vouched","type":"event"}]
|
@ -105,7 +105,7 @@ export default class BadgeReg {
|
|||||||
]);
|
]);
|
||||||
})
|
})
|
||||||
.then(([ title, icon ]) => {
|
.then(([ title, icon ]) => {
|
||||||
title = bytesToHex(title);
|
title = bytesToHex(title).replace(/(00)+$/, '');
|
||||||
title = title === ZERO32 ? null : hexToAscii(title);
|
title = title === ZERO32 ? null : hexToAscii(title);
|
||||||
|
|
||||||
if (bytesToHex(icon) === ZERO32) {
|
if (bytesToHex(icon) === ZERO32) {
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
left: 0;
|
left: 0;
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
padding: 1.5em;
|
padding: 1.5em;
|
||||||
|
cursor: pointer;
|
||||||
position: fixed;
|
position: fixed;
|
||||||
right: 50%;
|
right: 50%;
|
||||||
z-index: 100;
|
z-index: 100;
|
||||||
|
@ -43,8 +43,13 @@ export default class Application extends Component {
|
|||||||
contract: PropTypes.object
|
contract: PropTypes.object
|
||||||
};
|
};
|
||||||
|
|
||||||
|
state = {
|
||||||
|
hideWarning: false
|
||||||
|
};
|
||||||
|
|
||||||
render () {
|
render () {
|
||||||
const { isLoading, contract } = this.props;
|
const { isLoading, contract } = this.props;
|
||||||
|
const { hideWarning } = this.state;
|
||||||
|
|
||||||
if (isLoading) {
|
if (isLoading) {
|
||||||
return (
|
return (
|
||||||
@ -62,9 +67,15 @@ export default class Application extends Component {
|
|||||||
<Actions />
|
<Actions />
|
||||||
|
|
||||||
<Tokens />
|
<Tokens />
|
||||||
<div className={ styles.warning }>
|
{
|
||||||
WARNING: The token registry is experimental. Please ensure that you understand the steps, risks, benefits & consequences of registering a token before doing so. A non-refundable fee of { api.util.fromWei(contract.fee).toFormat(3) }<small>ETH</small> is required for all registrations.
|
hideWarning
|
||||||
</div>
|
? null
|
||||||
|
: (
|
||||||
|
<div className={ styles.warning } onClick={ this.handleHideWarning }>
|
||||||
|
WARNING: The token registry is experimental. Please ensure that you understand the steps, risks, benefits & consequences of registering a token before doing so. A non-refundable fee of { api.util.fromWei(contract.fee).toFormat(3) }<small>ETH</small> is required for all registrations.
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -74,4 +85,8 @@ export default class Application extends Component {
|
|||||||
muiTheme
|
muiTheme
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
handleHideWarning = () => {
|
||||||
|
this.setState({ hideWarning: true });
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,14 +14,6 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
export const fetchCertifiers = () => ({
|
|
||||||
type: 'fetchCertifiers'
|
|
||||||
});
|
|
||||||
|
|
||||||
export const fetchCertifications = (address) => ({
|
|
||||||
type: 'fetchCertifications', address
|
|
||||||
});
|
|
||||||
|
|
||||||
export const addCertification = (address, id, name, title, icon) => ({
|
export const addCertification = (address, id, name, title, icon) => ({
|
||||||
type: 'addCertification', address, id, name, title, icon
|
type: 'addCertification', address, id, name, title, icon
|
||||||
});
|
});
|
||||||
|
343
js/src/redux/providers/certifications/certifiers.monitor.js
Normal file
343
js/src/redux/providers/certifications/certifiers.monitor.js
Normal file
@ -0,0 +1,343 @@
|
|||||||
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
||||||
|
// This file is part of Parity.
|
||||||
|
|
||||||
|
// Parity is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
|
||||||
|
// Parity is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import { range } from 'lodash';
|
||||||
|
|
||||||
|
import { addCertification, removeCertification } from './actions';
|
||||||
|
|
||||||
|
import { getLogger, LOG_KEYS } from '~/config';
|
||||||
|
import Contract from '~/api/contract';
|
||||||
|
import { bytesToHex, hexToAscii } from '~/api/util/format';
|
||||||
|
import Contracts from '~/contracts';
|
||||||
|
import CertifierABI from '~/contracts/abi/certifier.json';
|
||||||
|
import { querier } from './enhanced-querier';
|
||||||
|
|
||||||
|
const log = getLogger(LOG_KEYS.CertificationsMiddleware);
|
||||||
|
|
||||||
|
let self = null;
|
||||||
|
|
||||||
|
export default class CertifiersMonitor {
|
||||||
|
constructor (api, store) {
|
||||||
|
this._api = api;
|
||||||
|
this._name = 'Certifiers';
|
||||||
|
this._store = store;
|
||||||
|
|
||||||
|
this._contract = new Contract(this.api, CertifierABI);
|
||||||
|
this._contractEvents = [ 'Confirmed', 'Revoked' ]
|
||||||
|
.map((name) => this.contract.events.find((e) => e.name === name));
|
||||||
|
|
||||||
|
this.certifiers = {};
|
||||||
|
this.fetchedAccounts = {};
|
||||||
|
|
||||||
|
this.load();
|
||||||
|
}
|
||||||
|
|
||||||
|
static get () {
|
||||||
|
if (self) {
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
self = new CertifiersMonitor();
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
static init (api, store) {
|
||||||
|
if (!self) {
|
||||||
|
self = new CertifiersMonitor(api, store);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
get api () {
|
||||||
|
return this._api;
|
||||||
|
}
|
||||||
|
|
||||||
|
get contract () {
|
||||||
|
return this._contract;
|
||||||
|
}
|
||||||
|
|
||||||
|
get contractEvents () {
|
||||||
|
return this._contractEvents;
|
||||||
|
}
|
||||||
|
|
||||||
|
get name () {
|
||||||
|
return this._name;
|
||||||
|
}
|
||||||
|
|
||||||
|
get store () {
|
||||||
|
return this._store;
|
||||||
|
}
|
||||||
|
|
||||||
|
get registry () {
|
||||||
|
return this._registry;
|
||||||
|
}
|
||||||
|
|
||||||
|
get registryEvents () {
|
||||||
|
return this._registryEvents;
|
||||||
|
}
|
||||||
|
|
||||||
|
checkFilters () {
|
||||||
|
this.checkCertifiersFilter();
|
||||||
|
this.checkRegistryFilter();
|
||||||
|
}
|
||||||
|
|
||||||
|
checkCertifiersFilter () {
|
||||||
|
if (!this.certifiersFilter) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.api.eth.getFilterChanges(this.certifiersFilter)
|
||||||
|
.then((logs) => {
|
||||||
|
if (logs.length === 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const parsedLogs = this.contract.parseEventLogs(logs).filter((log) => log.params);
|
||||||
|
|
||||||
|
log.debug('received certifiers logs', parsedLogs);
|
||||||
|
|
||||||
|
const promises = parsedLogs.map((log) => {
|
||||||
|
const account = log.params.who.value;
|
||||||
|
const certifier = Object.values(this.certifiers).find((c) => c.address === log.address);
|
||||||
|
|
||||||
|
if (!certifier) {
|
||||||
|
log.warn('could not find the certifier', { certifiers: this.certifiers, log });
|
||||||
|
return Promise.resolve();
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.fetchAccount(account, { ids: [ certifier.id ] });
|
||||||
|
});
|
||||||
|
|
||||||
|
return Promise.all(promises);
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
console.error(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
checkRegistryFilter () {
|
||||||
|
if (!this.registryFilter) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.api.eth.getFilterChanges(this.registryFilter)
|
||||||
|
.then((logs) => {
|
||||||
|
if (logs.length === 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const parsedLogs = this.contract.parseEventLogs(logs).filter((log) => log.params);
|
||||||
|
const indexes = parsedLogs.map((log) => log.params && log.params.id.value.toNumber());
|
||||||
|
|
||||||
|
log.debug('received registry logs', parsedLogs);
|
||||||
|
return this.fetchElements(indexes);
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
console.error(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initial load of the Monitor.
|
||||||
|
* Fetch the contract from the Registry, and
|
||||||
|
* load the elements addresses
|
||||||
|
*/
|
||||||
|
load () {
|
||||||
|
const badgeReg = Contracts.get().badgeReg;
|
||||||
|
|
||||||
|
log.debug(`loading the ${this.name} monitor...`);
|
||||||
|
return badgeReg.getContract()
|
||||||
|
.then((registryContract) => {
|
||||||
|
this._registry = registryContract;
|
||||||
|
this._registryEvents = [ 'Registered', 'Unregistered', 'MetaChanged', 'AddressChanged' ]
|
||||||
|
.map((name) => this.registry.events.find((e) => e.name === name));
|
||||||
|
|
||||||
|
return this.registry.instance.badgeCount.call({});
|
||||||
|
})
|
||||||
|
.then((count) => {
|
||||||
|
log.debug(`found ${count.toFormat()} registered contracts for ${this.name}`);
|
||||||
|
return this.fetchElements(range(count.toNumber()));
|
||||||
|
})
|
||||||
|
.then(() => {
|
||||||
|
return this.setRegistryFilter();
|
||||||
|
})
|
||||||
|
.then(() => {
|
||||||
|
// Listen for new blocks
|
||||||
|
return this.api.subscribe('eth_blockNumber', (err) => {
|
||||||
|
if (err) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.checkFilters();
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.then(() => {
|
||||||
|
log.debug(`loaded the ${this.name} monitor!`, this.certifiers);
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
log.error(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch the given registered element
|
||||||
|
*/
|
||||||
|
fetchElements (indexes) {
|
||||||
|
const badgeReg = Contracts.get().badgeReg;
|
||||||
|
const { instance } = this.registry;
|
||||||
|
|
||||||
|
const sorted = indexes.sort();
|
||||||
|
const from = sorted[0];
|
||||||
|
const last = sorted[sorted.length - 1];
|
||||||
|
const limit = last - from + 1;
|
||||||
|
|
||||||
|
// Fetch the address, name and owner in one batch
|
||||||
|
return querier(this.api, { address: instance.address, from, limit }, instance.badge)
|
||||||
|
.then((results) => {
|
||||||
|
const certifiers = results
|
||||||
|
.map(([ address, name, owner ], index) => ({
|
||||||
|
address, owner,
|
||||||
|
id: index + from,
|
||||||
|
name: hexToAscii(bytesToHex(name).replace(/(00)+$/, ''))
|
||||||
|
}))
|
||||||
|
.reduce((certifiers, certifier) => {
|
||||||
|
const { id } = certifier;
|
||||||
|
|
||||||
|
if (!/^(0x)?0+$/.test(certifier.address)) {
|
||||||
|
certifiers[id] = certifier;
|
||||||
|
} else if (certifiers[id]) {
|
||||||
|
delete certifiers[id];
|
||||||
|
}
|
||||||
|
|
||||||
|
return certifiers;
|
||||||
|
}, {});
|
||||||
|
|
||||||
|
// Fetch the meta-data in serie
|
||||||
|
return Object.values(certifiers).reduce((promise, certifier) => {
|
||||||
|
return promise.then(() => badgeReg.fetchMeta(certifier.id))
|
||||||
|
.then((meta) => {
|
||||||
|
this.certifiers[certifier.id] = { ...certifier, ...meta };
|
||||||
|
});
|
||||||
|
}, Promise.resolve());
|
||||||
|
})
|
||||||
|
.then(() => log.debug('fetched certifiers', { certifiers: this.certifiers }))
|
||||||
|
// Fetch the know accounts in case it's an update of the certifiers
|
||||||
|
.then(() => this.fetchAccounts(Object.keys(this.fetchedAccounts), { ids: indexes, force: true }));
|
||||||
|
}
|
||||||
|
|
||||||
|
fetchAccounts (addresses, { ids = null, force = false } = {}) {
|
||||||
|
const newAddresses = force
|
||||||
|
? addresses
|
||||||
|
: addresses.filter((address) => !this.fetchedAccounts[address]);
|
||||||
|
|
||||||
|
if (newAddresses.length === 0) {
|
||||||
|
return Promise.resolve();
|
||||||
|
}
|
||||||
|
|
||||||
|
log.debug(`fetching values for "${addresses.join(' ; ')}" in ${this.name}...`);
|
||||||
|
return newAddresses
|
||||||
|
.reduce((promise, address) => {
|
||||||
|
return promise.then(() => this.fetchAccount(address, { ids }));
|
||||||
|
}, Promise.resolve())
|
||||||
|
.then(() => {
|
||||||
|
log.debug(`fetched values for "${addresses.join(' ; ')}" in ${this.name}!`);
|
||||||
|
})
|
||||||
|
.then(() => this.setCertifiersFilter());
|
||||||
|
}
|
||||||
|
|
||||||
|
fetchAccount (address, { ids = null } = {}) {
|
||||||
|
let certifiers = Object.values(this.certifiers);
|
||||||
|
|
||||||
|
// Only fetch values for the givens ids, if any
|
||||||
|
if (ids) {
|
||||||
|
certifiers = certifiers.filter((certifier) => ids.includes(certifier.id));
|
||||||
|
}
|
||||||
|
|
||||||
|
certifiers
|
||||||
|
.reduce((promise, certifier) => {
|
||||||
|
return promise
|
||||||
|
.then(() => {
|
||||||
|
return this.contract.at(certifier.address).instance.certified.call({}, [ address ]);
|
||||||
|
})
|
||||||
|
.then((certified) => {
|
||||||
|
const { id, title, icon, name } = certifier;
|
||||||
|
|
||||||
|
if (!certified) {
|
||||||
|
return this.store.dispatch(removeCertification(address, id));
|
||||||
|
}
|
||||||
|
|
||||||
|
log.debug('seen as certified', { address, id, name, icon });
|
||||||
|
this.store.dispatch(addCertification(address, id, name, title, icon));
|
||||||
|
});
|
||||||
|
}, Promise.resolve())
|
||||||
|
.then(() => {
|
||||||
|
this.fetchedAccounts[address] = true;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
setCertifiersFilter () {
|
||||||
|
const accounts = Object.keys(this.fetchedAccounts);
|
||||||
|
const addresses = Object.values(this.certifiers).map((c) => c.address);
|
||||||
|
// The events have as first indexed data the account address
|
||||||
|
const topics = [
|
||||||
|
this.contractEvents.map((event) => '0x' + event.signature),
|
||||||
|
accounts
|
||||||
|
];
|
||||||
|
|
||||||
|
if (accounts.length === 0 || addresses.length === 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const promise = this.certifiersFilter
|
||||||
|
? this.api.eth.uninstallFilter(this.certifiersFilter)
|
||||||
|
: Promise.resolve();
|
||||||
|
|
||||||
|
log.debug('setting up registry filter', { topics, accounts, addresses });
|
||||||
|
|
||||||
|
return promise
|
||||||
|
.then(() => this.api.eth.newFilter({
|
||||||
|
fromBlock: 'latest',
|
||||||
|
toBlock: 'latest',
|
||||||
|
address: addresses,
|
||||||
|
topics
|
||||||
|
}))
|
||||||
|
.then((filterId) => {
|
||||||
|
this.certifiersFilter = filterId;
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
console.error(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
setRegistryFilter () {
|
||||||
|
const { address } = this.registry.instance;
|
||||||
|
const topics = [ this.registryEvents.map((event) => '0x' + event.signature) ];
|
||||||
|
|
||||||
|
log.debug('setting up registry filter', { topics, address });
|
||||||
|
|
||||||
|
return this.api.eth
|
||||||
|
.newFilter({
|
||||||
|
fromBlock: 'latest',
|
||||||
|
toBlock: 'latest',
|
||||||
|
address, topics
|
||||||
|
})
|
||||||
|
.then((filterId) => {
|
||||||
|
this.registryFilter = filterId;
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
console.error(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
96
js/src/redux/providers/certifications/enhanced-querier.js
Normal file
96
js/src/redux/providers/certifications/enhanced-querier.js
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
||||||
|
// This file is part of Parity.
|
||||||
|
|
||||||
|
// Parity is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
|
||||||
|
// Parity is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import { padRight, padLeft } from '~/api/util/format';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Bytecode of this contract:
|
||||||
|
*
|
||||||
|
*
|
||||||
|
pragma solidity ^0.4.10;
|
||||||
|
|
||||||
|
contract Querier {
|
||||||
|
function Querier
|
||||||
|
(address addr, bytes32 sign, uint out_size, uint from, uint limit)
|
||||||
|
public
|
||||||
|
{
|
||||||
|
// The size is 32 bytes for each
|
||||||
|
// value, plus 32 bytes for the count
|
||||||
|
uint m_size = out_size * limit + 32;
|
||||||
|
|
||||||
|
bytes32 p_return;
|
||||||
|
uint p_in;
|
||||||
|
uint p_out;
|
||||||
|
|
||||||
|
assembly {
|
||||||
|
p_return := mload(0x40)
|
||||||
|
mstore(0x40, add(p_return, m_size))
|
||||||
|
|
||||||
|
mstore(p_return, limit)
|
||||||
|
|
||||||
|
p_in := mload(0x40)
|
||||||
|
mstore(0x40, add(p_in, 0x24))
|
||||||
|
|
||||||
|
mstore(p_in, sign)
|
||||||
|
|
||||||
|
p_out := add(p_return, 0x20)
|
||||||
|
}
|
||||||
|
|
||||||
|
for (uint i = from; i < from + limit; i++) {
|
||||||
|
assembly {
|
||||||
|
mstore(add(p_in, 0x4), i)
|
||||||
|
call(gas, addr, 0x0, p_in, 0x24, p_out, out_size)
|
||||||
|
p_out := add(p_out, out_size)
|
||||||
|
pop
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
assembly {
|
||||||
|
return (p_return, m_size)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
export const bytecode = '0x60606040523415600e57600080fd5b60405160a0806099833981016040528080519190602001805191906020018051919060200180519190602001805191505082810260200160008080806040519350848401604052858452604051602481016040528981529250505060208201855b858701811015609457806004840152878260248560008e5af15090870190600101606f565b8484f300';
|
||||||
|
|
||||||
|
export const querier = (api, { address, from, limit }, method) => {
|
||||||
|
const { outputs, signature } = method;
|
||||||
|
const outLength = 32 * outputs.length;
|
||||||
|
const callargs = [
|
||||||
|
padLeft(address, 32),
|
||||||
|
padRight(signature, 32),
|
||||||
|
padLeft(outLength, 32),
|
||||||
|
padLeft(from, 32),
|
||||||
|
padLeft(limit, 32)
|
||||||
|
].map((v) => v.slice(2)).join('');
|
||||||
|
const calldata = bytecode + callargs;
|
||||||
|
|
||||||
|
return api.eth.call({ data: calldata })
|
||||||
|
.then((result) => {
|
||||||
|
const data = result.slice(2);
|
||||||
|
const results = [];
|
||||||
|
|
||||||
|
for (let i = 0; i < limit; i++) {
|
||||||
|
const datum = data.substr(2 * (32 + i * outLength), 2 * outLength);
|
||||||
|
const decoded = method.decodeOutput('0x' + datum).map((t) => t.value);
|
||||||
|
|
||||||
|
results.push(decoded);
|
||||||
|
}
|
||||||
|
|
||||||
|
return results;
|
||||||
|
});
|
||||||
|
};
|
@ -14,222 +14,22 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
import { uniq, range, debounce } from 'lodash';
|
|
||||||
|
|
||||||
import { addCertification, removeCertification } from './actions';
|
|
||||||
|
|
||||||
import { getLogger, LOG_KEYS } from '~/config';
|
|
||||||
import Contract from '~/api/contract';
|
|
||||||
import Contracts from '~/contracts';
|
import Contracts from '~/contracts';
|
||||||
import CertifierABI from '~/contracts/abi/certifier.json';
|
import Monitor from './certifiers.monitor';
|
||||||
|
|
||||||
const log = getLogger(LOG_KEYS.CertificationsMiddleware);
|
|
||||||
|
|
||||||
// TODO: move this to a more general place
|
|
||||||
const updatableFilter = (api, onFilter) => {
|
|
||||||
let filter = null;
|
|
||||||
|
|
||||||
const update = (address, topics) => {
|
|
||||||
if (filter) {
|
|
||||||
filter = filter.then((filterId) => {
|
|
||||||
api.eth.uninstallFilter(filterId);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
filter = (filter || Promise.resolve())
|
|
||||||
.then(() => api.eth.newFilter({
|
|
||||||
fromBlock: 'latest',
|
|
||||||
toBlock: 'latest',
|
|
||||||
address,
|
|
||||||
topics
|
|
||||||
}))
|
|
||||||
.then((filterId) => {
|
|
||||||
onFilter(filterId);
|
|
||||||
return filterId;
|
|
||||||
})
|
|
||||||
.catch((err) => {
|
|
||||||
console.error('Failed to create certifications filter:', err);
|
|
||||||
});
|
|
||||||
|
|
||||||
return filter;
|
|
||||||
};
|
|
||||||
|
|
||||||
return update;
|
|
||||||
};
|
|
||||||
|
|
||||||
export default class CertificationsMiddleware {
|
export default class CertificationsMiddleware {
|
||||||
toMiddleware () {
|
toMiddleware () {
|
||||||
const api = Contracts.get()._api;
|
const api = Contracts.get()._api;
|
||||||
const badgeReg = Contracts.get().badgeReg;
|
|
||||||
|
|
||||||
const contract = new Contract(api, CertifierABI);
|
|
||||||
const Confirmed = contract.events.find((e) => e.name === 'Confirmed');
|
|
||||||
const Revoked = contract.events.find((e) => e.name === 'Revoked');
|
|
||||||
|
|
||||||
return (store) => {
|
return (store) => {
|
||||||
let certifiers = [];
|
Monitor.init(api, store);
|
||||||
let addresses = [];
|
|
||||||
let filterChanged = false;
|
|
||||||
let filter = null;
|
|
||||||
let badgeRegFilter = null;
|
|
||||||
let fetchCertifiersPromise = null;
|
|
||||||
|
|
||||||
const updateFilter = updatableFilter(api, (filterId) => {
|
|
||||||
filterChanged = true;
|
|
||||||
filter = filterId;
|
|
||||||
});
|
|
||||||
|
|
||||||
const badgeRegUpdateFilter = updatableFilter(api, (filterId) => {
|
|
||||||
filterChanged = true;
|
|
||||||
badgeRegFilter = filterId;
|
|
||||||
});
|
|
||||||
|
|
||||||
badgeReg
|
|
||||||
.getContract()
|
|
||||||
.then((badgeRegContract) => {
|
|
||||||
return badgeRegUpdateFilter(badgeRegContract.address, [ [
|
|
||||||
badgeRegContract.instance.Registered.signature,
|
|
||||||
badgeRegContract.instance.Unregistered.signature,
|
|
||||||
badgeRegContract.instance.MetaChanged.signature,
|
|
||||||
badgeRegContract.instance.AddressChanged.signature
|
|
||||||
] ]);
|
|
||||||
})
|
|
||||||
.then(() => {
|
|
||||||
shortFetchChanges();
|
|
||||||
|
|
||||||
api.subscribe('eth_blockNumber', (err) => {
|
|
||||||
if (err) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
fetchChanges();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
function onLogs (logs) {
|
|
||||||
logs = contract.parseEventLogs(logs);
|
|
||||||
logs.forEach((log) => {
|
|
||||||
const certifier = certifiers.find((c) => c.address === log.address);
|
|
||||||
|
|
||||||
if (!certifier) {
|
|
||||||
throw new Error(`Could not find certifier at ${log.address}.`);
|
|
||||||
}
|
|
||||||
const { id, name, title, icon } = certifier;
|
|
||||||
|
|
||||||
if (log.event === 'Revoked') {
|
|
||||||
store.dispatch(removeCertification(log.params.who.value, id));
|
|
||||||
} else {
|
|
||||||
store.dispatch(addCertification(log.params.who.value, id, name, title, icon));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function onBadgeRegLogs (logs) {
|
|
||||||
return badgeReg.getContract()
|
|
||||||
.then((badgeRegContract) => {
|
|
||||||
logs = badgeRegContract.parseEventLogs(logs);
|
|
||||||
|
|
||||||
const ids = logs.map((log) => log.params && log.params.id.value.toNumber());
|
|
||||||
|
|
||||||
return fetchCertifiers(uniq(ids));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function _fetchChanges () {
|
|
||||||
const method = filterChanged
|
|
||||||
? 'getFilterLogs'
|
|
||||||
: 'getFilterChanges';
|
|
||||||
|
|
||||||
filterChanged = false;
|
|
||||||
|
|
||||||
api.eth[method](badgeRegFilter)
|
|
||||||
.then(onBadgeRegLogs)
|
|
||||||
.catch((err) => {
|
|
||||||
console.error('Failed to fetch badge reg events:', err);
|
|
||||||
})
|
|
||||||
.then(() => api.eth[method](filter))
|
|
||||||
.then(onLogs)
|
|
||||||
.catch((err) => {
|
|
||||||
console.error('Failed to fetch new certifier events:', err);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
const shortFetchChanges = debounce(_fetchChanges, 0.5 * 1000, { leading: true });
|
|
||||||
const fetchChanges = debounce(shortFetchChanges, 10 * 1000, { leading: true });
|
|
||||||
|
|
||||||
function fetchConfirmedEvents () {
|
|
||||||
return updateFilter(certifiers.map((c) => c.address), [
|
|
||||||
[ Confirmed.signature, Revoked.signature ],
|
|
||||||
addresses
|
|
||||||
]).then(() => shortFetchChanges());
|
|
||||||
}
|
|
||||||
|
|
||||||
function fetchCertifiers (ids = []) {
|
|
||||||
if (fetchCertifiersPromise) {
|
|
||||||
return fetchCertifiersPromise;
|
|
||||||
}
|
|
||||||
|
|
||||||
let fetchEvents = false;
|
|
||||||
|
|
||||||
const idsPromise = (certifiers.length === 0)
|
|
||||||
? badgeReg.certifierCount().then((count) => {
|
|
||||||
return range(count);
|
|
||||||
})
|
|
||||||
: Promise.resolve(ids);
|
|
||||||
|
|
||||||
fetchCertifiersPromise = idsPromise
|
|
||||||
.then((ids) => {
|
|
||||||
const promises = ids.map((id) => {
|
|
||||||
return badgeReg.fetchCertifier(id)
|
|
||||||
.then((cert) => {
|
|
||||||
if (!certifiers.some((c) => c.id === cert.id)) {
|
|
||||||
certifiers = certifiers.concat(cert);
|
|
||||||
fetchEvents = true;
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.catch((err) => {
|
|
||||||
if (/does not exist/.test(err.toString())) {
|
|
||||||
return log.info(err.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
log.warn(`Could not fetch certifier ${id}:`, err);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
return Promise
|
|
||||||
.all(promises)
|
|
||||||
.then(() => {
|
|
||||||
fetchCertifiersPromise = null;
|
|
||||||
|
|
||||||
if (fetchEvents) {
|
|
||||||
return fetchConfirmedEvents();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
return fetchCertifiersPromise;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (next) => (action) => {
|
return (next) => (action) => {
|
||||||
switch (action.type) {
|
switch (action.type) {
|
||||||
case 'fetchCertifiers':
|
|
||||||
fetchConfirmedEvents();
|
|
||||||
|
|
||||||
break;
|
|
||||||
case 'fetchCertifications':
|
|
||||||
const { address } = action;
|
|
||||||
|
|
||||||
if (!addresses.includes(address)) {
|
|
||||||
addresses = addresses.concat(address);
|
|
||||||
fetchConfirmedEvents();
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
case 'setVisibleAccounts':
|
case 'setVisibleAccounts':
|
||||||
const _addresses = action.addresses || [];
|
const { addresses = [] } = action;
|
||||||
|
|
||||||
addresses = uniq(addresses.concat(_addresses));
|
Monitor.get().fetchAccounts(addresses);
|
||||||
fetchConfirmedEvents();
|
|
||||||
next(action);
|
next(action);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
@ -20,24 +20,32 @@ export default (state = initialState, action) => {
|
|||||||
if (action.type === 'addCertification') {
|
if (action.type === 'addCertification') {
|
||||||
const { address, id, name, icon, title } = action;
|
const { address, id, name, icon, title } = action;
|
||||||
const certifications = state[address] || [];
|
const certifications = state[address] || [];
|
||||||
|
const certifierIndex = certifications.findIndex((c) => c.id === id);
|
||||||
|
const data = { id, name, icon, title };
|
||||||
|
const nextCertifications = certifications.slice();
|
||||||
|
|
||||||
if (certifications.some((c) => c.id === id)) {
|
if (certifierIndex >= 0) {
|
||||||
return state;
|
nextCertifications[certifierIndex] = data;
|
||||||
|
} else {
|
||||||
|
nextCertifications.push(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
const newCertifications = certifications.concat({
|
return { ...state, [address]: nextCertifications };
|
||||||
id, name, icon, title
|
|
||||||
});
|
|
||||||
|
|
||||||
return { ...state, [address]: newCertifications };
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (action.type === 'removeCertification') {
|
if (action.type === 'removeCertification') {
|
||||||
const { address, id } = action;
|
const { address, id } = action;
|
||||||
const certifications = state[address] || [];
|
const certifications = state[address] || [];
|
||||||
|
const certifierIndex = certifications.findIndex((c) => c.id === id);
|
||||||
|
|
||||||
const newCertifications = certifications.filter((c) => c.id !== id);
|
// Don't remove if not there
|
||||||
|
if (certifierIndex < 0) {
|
||||||
|
return state;
|
||||||
|
}
|
||||||
|
|
||||||
|
const newCertifications = certifications.slice();
|
||||||
|
|
||||||
|
newCertifications.splice(certifierIndex, 1);
|
||||||
return { ...state, [address]: newCertifications };
|
return { ...state, [address]: newCertifications };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,13 +54,24 @@ export const watchRequest = (request) => (dispatch, getState) => {
|
|||||||
dispatch(trackRequest(requestId, request));
|
dispatch(trackRequest(requestId, request));
|
||||||
};
|
};
|
||||||
|
|
||||||
export const trackRequest = (requestId, { transactionHash = null } = {}) => (dispatch, getState) => {
|
export const trackRequest = (requestId, { transactionHash = null, retries = 0 } = {}) => (dispatch, getState) => {
|
||||||
const { api } = getState();
|
const { api } = getState();
|
||||||
|
|
||||||
trackRequestUtil(api, { requestId, transactionHash }, (error, _data = {}) => {
|
trackRequestUtil(api, { requestId, transactionHash }, (error, _data = {}) => {
|
||||||
const data = { ..._data };
|
const data = { ..._data };
|
||||||
|
|
||||||
if (error) {
|
if (error) {
|
||||||
|
// Retry in 500ms if request not found, max 5 times
|
||||||
|
if (error.type === 'REQUEST_NOT_FOUND') {
|
||||||
|
if (retries > 5) {
|
||||||
|
return dispatch(deleteRequest(requestId));
|
||||||
|
}
|
||||||
|
|
||||||
|
return setTimeout(() => {
|
||||||
|
trackRequest(requestId, { transactionHash, retries: retries + 1 })(dispatch, getState);
|
||||||
|
}, 500);
|
||||||
|
}
|
||||||
|
|
||||||
console.error(error);
|
console.error(error);
|
||||||
return dispatch(setRequest(requestId, { error }));
|
return dispatch(setRequest(requestId, { error }));
|
||||||
}
|
}
|
||||||
|
@ -115,9 +115,11 @@ export function loadTokensBasics (_tokenIndexes, options) {
|
|||||||
const prevTokensIndexes = Object.values(tokens).map((t) => t.index);
|
const prevTokensIndexes = Object.values(tokens).map((t) => t.index);
|
||||||
|
|
||||||
// Only fetch tokens we don't have yet
|
// Only fetch tokens we don't have yet
|
||||||
const tokenIndexes = _tokenIndexes.filter((tokenIndex) => {
|
const tokenIndexes = _tokenIndexes
|
||||||
return !prevTokensIndexes.includes(tokenIndex);
|
.filter((tokenIndex) => {
|
||||||
});
|
return !prevTokensIndexes.includes(tokenIndex);
|
||||||
|
})
|
||||||
|
.sort();
|
||||||
|
|
||||||
const count = tokenIndexes.length;
|
const count = tokenIndexes.length;
|
||||||
|
|
||||||
@ -130,10 +132,15 @@ export function loadTokensBasics (_tokenIndexes, options) {
|
|||||||
return tokenReg.getContract()
|
return tokenReg.getContract()
|
||||||
.then((tokenRegContract) => {
|
.then((tokenRegContract) => {
|
||||||
let promise = Promise.resolve();
|
let promise = Promise.resolve();
|
||||||
|
const first = tokenIndexes[0];
|
||||||
|
const last = tokenIndexes[tokenIndexes.length - 1];
|
||||||
|
|
||||||
|
for (let from = first; from <= last; from += limit) {
|
||||||
|
// No need to fetch `limit` elements
|
||||||
|
const lowerLimit = Math.min(limit, last - from + 1);
|
||||||
|
|
||||||
for (let start = 0; start < count; start += limit) {
|
|
||||||
promise = promise
|
promise = promise
|
||||||
.then(() => fetchTokensBasics(api, tokenRegContract, start, limit))
|
.then(() => fetchTokensBasics(api, tokenRegContract, from, lowerLimit))
|
||||||
.then((results) => {
|
.then((results) => {
|
||||||
results
|
results
|
||||||
.forEach((token) => {
|
.forEach((token) => {
|
||||||
|
@ -20,7 +20,6 @@
|
|||||||
background-color: rgba(0, 0, 0, 0.8);
|
background-color: rgba(0, 0, 0, 0.8);
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
height: 100%;
|
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
transition: transform ease-out 0.1s;
|
transition: transform ease-out 0.1s;
|
||||||
transform: scale(1);
|
transform: scale(1);
|
||||||
|
@ -15,11 +15,12 @@
|
|||||||
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
import BigNumber from 'bignumber.js';
|
import BigNumber from 'bignumber.js';
|
||||||
|
import { pick } from 'lodash';
|
||||||
import React, { Component, PropTypes } from 'react';
|
import React, { Component, PropTypes } from 'react';
|
||||||
import { FormattedMessage } from 'react-intl';
|
import { FormattedMessage } from 'react-intl';
|
||||||
import { connect } from 'react-redux';
|
import { connect } from 'react-redux';
|
||||||
|
|
||||||
import TokenImage from '~/ui/TokenImage';
|
import TokenValue from './tokenValue';
|
||||||
|
|
||||||
import styles from './balance.css';
|
import styles from './balance.css';
|
||||||
|
|
||||||
@ -69,58 +70,19 @@ export class Balance extends Component {
|
|||||||
const balanceValue = balance[tokenId];
|
const balanceValue = balance[tokenId];
|
||||||
|
|
||||||
const isEthToken = token.native;
|
const isEthToken = token.native;
|
||||||
const isFullToken = !showOnlyEth || isEthToken;
|
|
||||||
const hasBalance = (balanceValue instanceof BigNumber) && balanceValue.gt(0);
|
const hasBalance = (balanceValue instanceof BigNumber) && balanceValue.gt(0);
|
||||||
|
|
||||||
if (!hasBalance && !isEthToken) {
|
if (!hasBalance && !isEthToken) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
const bnf = new BigNumber(token.format || 1);
|
|
||||||
let decimals = 0;
|
|
||||||
|
|
||||||
if (bnf.gte(1000)) {
|
|
||||||
decimals = 3;
|
|
||||||
} else if (bnf.gte(100)) {
|
|
||||||
decimals = 2;
|
|
||||||
} else if (bnf.gte(10)) {
|
|
||||||
decimals = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
const rawValue = new BigNumber(balanceValue).div(bnf);
|
|
||||||
const value = rawValue.toFormat(decimals);
|
|
||||||
|
|
||||||
const classNames = [styles.balance];
|
|
||||||
let details = null;
|
|
||||||
|
|
||||||
if (isFullToken) {
|
|
||||||
classNames.push(styles.full);
|
|
||||||
details = [
|
|
||||||
<div
|
|
||||||
className={ styles.value }
|
|
||||||
key='value'
|
|
||||||
>
|
|
||||||
<span title={ `${rawValue.toFormat()} ${token.tag}` }>
|
|
||||||
{ value }
|
|
||||||
</span>
|
|
||||||
</div>,
|
|
||||||
<div
|
|
||||||
className={ styles.tag }
|
|
||||||
key='tag'
|
|
||||||
>
|
|
||||||
{ token.tag }
|
|
||||||
</div>
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<TokenValue
|
||||||
className={ classNames.join(' ') }
|
|
||||||
key={ tokenId }
|
key={ tokenId }
|
||||||
>
|
showOnlyEth={ showOnlyEth }
|
||||||
<TokenImage token={ token } />
|
token={ token }
|
||||||
{ details }
|
value={ balanceValue }
|
||||||
</div>
|
/>
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
.filter((node) => node);
|
.filter((node) => node);
|
||||||
@ -155,11 +117,15 @@ export class Balance extends Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function mapStateToProps (state, props) {
|
function mapStateToProps (state, props) {
|
||||||
const { balances, tokens } = state;
|
const { balances, tokens: allTokens } = state;
|
||||||
const { address } = props;
|
const { address } = props;
|
||||||
|
const balance = balances[address] || props.balance || {};
|
||||||
|
|
||||||
|
const tokenIds = Object.keys(balance);
|
||||||
|
const tokens = pick(allTokens, tokenIds);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
balance: balances[address] || props.balance || {},
|
balance,
|
||||||
tokens
|
tokens
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -84,13 +84,13 @@ describe('ui/Balance', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('renders all the non-zero balances', () => {
|
it('renders all the non-zero balances', () => {
|
||||||
expect(component.find('Connect(TokenImage)')).to.have.length(2);
|
expect(component.find('Connect(TokenValue)')).to.have.length(2);
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('render specifiers', () => {
|
describe('render specifiers', () => {
|
||||||
it('renders all the tokens with showZeroValues', () => {
|
it('renders all the tokens with showZeroValues', () => {
|
||||||
render({ showZeroValues: true });
|
render({ showZeroValues: true });
|
||||||
expect(component.find('Connect(TokenImage)')).to.have.length(2);
|
expect(component.find('Connect(TokenValue)')).to.have.length(2);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
109
js/src/ui/Balance/tokenValue.js
Normal file
109
js/src/ui/Balance/tokenValue.js
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
||||||
|
// This file is part of Parity.
|
||||||
|
|
||||||
|
// Parity is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
|
||||||
|
// Parity is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import BigNumber from 'bignumber.js';
|
||||||
|
import React, { Component, PropTypes } from 'react';
|
||||||
|
import { connect } from 'react-redux';
|
||||||
|
import { bindActionCreators } from 'redux';
|
||||||
|
|
||||||
|
import { fetchTokens } from '~/redux/providers/tokensActions';
|
||||||
|
import TokenImage from '~/ui/TokenImage';
|
||||||
|
|
||||||
|
import styles from './balance.css';
|
||||||
|
|
||||||
|
class TokenValue extends Component {
|
||||||
|
static propTypes = {
|
||||||
|
token: PropTypes.object.isRequired,
|
||||||
|
value: PropTypes.object.isRequired,
|
||||||
|
|
||||||
|
// Redux injection
|
||||||
|
fetchTokens: PropTypes.func.isRequired,
|
||||||
|
|
||||||
|
showOnlyEth: PropTypes.bool
|
||||||
|
};
|
||||||
|
|
||||||
|
componentWillMount () {
|
||||||
|
const { token } = this.props;
|
||||||
|
|
||||||
|
if (token.native) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!token.fetched) {
|
||||||
|
if (!Number.isFinite(token.index)) {
|
||||||
|
return console.warn('no token index', token);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.props.fetchTokens([ token.index ]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
render () {
|
||||||
|
const { token, showOnlyEth, value } = this.props;
|
||||||
|
|
||||||
|
const isEthToken = token.native;
|
||||||
|
const isFullToken = !showOnlyEth || isEthToken;
|
||||||
|
|
||||||
|
const bnf = new BigNumber(token.format || 1);
|
||||||
|
let decimals = 0;
|
||||||
|
|
||||||
|
if (bnf.gte(1000)) {
|
||||||
|
decimals = 3;
|
||||||
|
} else if (bnf.gte(100)) {
|
||||||
|
decimals = 2;
|
||||||
|
} else if (bnf.gte(10)) {
|
||||||
|
decimals = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
const rawValue = new BigNumber(value).div(bnf);
|
||||||
|
const classNames = [styles.balance];
|
||||||
|
|
||||||
|
if (isFullToken) {
|
||||||
|
classNames.push(styles.full);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className={ classNames.join(' ') }>
|
||||||
|
<TokenImage token={ token } />
|
||||||
|
{
|
||||||
|
isFullToken
|
||||||
|
? [
|
||||||
|
<div className={ styles.value } key='value'>
|
||||||
|
<span title={ `${rawValue.toFormat()} ${token.tag}` }>
|
||||||
|
{ rawValue.toFormat(decimals) }
|
||||||
|
</span>
|
||||||
|
</div>,
|
||||||
|
<div className={ styles.tag } key='tag'>
|
||||||
|
{ token.tag }
|
||||||
|
</div>
|
||||||
|
]
|
||||||
|
: null
|
||||||
|
}
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function mapDispatchToProps (dispatch) {
|
||||||
|
return bindActionCreators({
|
||||||
|
fetchTokens
|
||||||
|
}, dispatch);
|
||||||
|
}
|
||||||
|
|
||||||
|
export default connect(
|
||||||
|
null,
|
||||||
|
mapDispatchToProps
|
||||||
|
)(TokenValue);
|
@ -19,6 +19,7 @@ import React, { Component, PropTypes } from 'react';
|
|||||||
import Container, { Title as ContainerTitle } from '~/ui/Container';
|
import Container, { Title as ContainerTitle } from '~/ui/Container';
|
||||||
import DappIcon from '~/ui/DappIcon';
|
import DappIcon from '~/ui/DappIcon';
|
||||||
import Tags from '~/ui/Tags';
|
import Tags from '~/ui/Tags';
|
||||||
|
import DappVouchFor from '../DappVouchFor';
|
||||||
|
|
||||||
import styles from './dappCard.css';
|
import styles from './dappCard.css';
|
||||||
|
|
||||||
@ -61,6 +62,7 @@ export default class DappCard extends Component {
|
|||||||
app={ app }
|
app={ app }
|
||||||
className={ styles.image }
|
className={ styles.image }
|
||||||
/>
|
/>
|
||||||
|
<DappVouchFor app={ app } />
|
||||||
<Tags
|
<Tags
|
||||||
className={ styles.tags }
|
className={ styles.tags }
|
||||||
tags={
|
tags={
|
||||||
|
43
js/src/ui/DappVouchFor/dappVouchFor.css
Normal file
43
js/src/ui/DappVouchFor/dappVouchFor.css
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
/* Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
||||||
|
/* This file is part of Parity.
|
||||||
|
/*
|
||||||
|
/* Parity is free software: you can redistribute it and/or modify
|
||||||
|
/* it under the terms of the GNU General Public License as published by
|
||||||
|
/* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
/* (at your option) any later version.
|
||||||
|
/*
|
||||||
|
/* Parity is distributed in the hope that it will be useful,
|
||||||
|
/* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
/* GNU General Public License for more details.
|
||||||
|
/*
|
||||||
|
/* You should have received a copy of the GNU General Public License
|
||||||
|
/* along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
.tag {
|
||||||
|
color: inherit;
|
||||||
|
position: absolute;
|
||||||
|
top: 1em;
|
||||||
|
right: 1em;
|
||||||
|
|
||||||
|
.image {
|
||||||
|
position: absolute;
|
||||||
|
right: 0;
|
||||||
|
top: 0;
|
||||||
|
width: 32px;
|
||||||
|
height: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bubble {
|
||||||
|
background: red;
|
||||||
|
border-radius: 0.25em;
|
||||||
|
color: white;
|
||||||
|
font-size: 0.75em;
|
||||||
|
padding: 0.1em 0.5em;
|
||||||
|
position: absolute;
|
||||||
|
right: 0;
|
||||||
|
top: 0;
|
||||||
|
z-index: 100;
|
||||||
|
}
|
||||||
|
}
|
57
js/src/ui/DappVouchFor/dappVouchFor.js
Normal file
57
js/src/ui/DappVouchFor/dappVouchFor.js
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
||||||
|
// This file is part of Parity.
|
||||||
|
|
||||||
|
// Parity is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
|
||||||
|
// Parity is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import React, { Component, PropTypes } from 'react';
|
||||||
|
import { observer } from 'mobx-react';
|
||||||
|
|
||||||
|
import IdentityIcon from '../IdentityIcon';
|
||||||
|
|
||||||
|
import Store from './store';
|
||||||
|
import styles from './dappVouchFor.css';
|
||||||
|
|
||||||
|
@observer
|
||||||
|
export default class DappVouchFor extends Component {
|
||||||
|
static contextTypes = {
|
||||||
|
api: PropTypes.object.isRequired
|
||||||
|
};
|
||||||
|
|
||||||
|
static propTypes = {
|
||||||
|
app: PropTypes.object.isRequired
|
||||||
|
};
|
||||||
|
|
||||||
|
store = new Store(this.context.api, this.props.app);
|
||||||
|
|
||||||
|
render () {
|
||||||
|
const count = this.store.vouchers.length;
|
||||||
|
|
||||||
|
if (!count) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className={ styles.tag }>
|
||||||
|
<IdentityIcon
|
||||||
|
address={ this.store.vouchers[0] }
|
||||||
|
className={ styles.image }
|
||||||
|
alt={ `${count} identities vouch for this dapp` }
|
||||||
|
/>
|
||||||
|
<div className={ styles.bubble }>
|
||||||
|
{ count }
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
17
js/src/ui/DappVouchFor/index.js
Normal file
17
js/src/ui/DappVouchFor/index.js
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
||||||
|
// This file is part of Parity.
|
||||||
|
|
||||||
|
// Parity is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
|
||||||
|
// Parity is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
export default from './dappVouchFor';
|
87
js/src/ui/DappVouchFor/store.js
Normal file
87
js/src/ui/DappVouchFor/store.js
Normal file
@ -0,0 +1,87 @@
|
|||||||
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
||||||
|
// This file is part of Parity.
|
||||||
|
|
||||||
|
// Parity is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
|
||||||
|
// Parity is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import { action, observable } from 'mobx';
|
||||||
|
import { uniq } from 'lodash';
|
||||||
|
|
||||||
|
import Contracts from '~/contracts';
|
||||||
|
import { vouchfor as vouchForAbi } from '~/contracts/abi';
|
||||||
|
|
||||||
|
let contractPromise = null;
|
||||||
|
|
||||||
|
export default class Store {
|
||||||
|
@observable vouchers = [];
|
||||||
|
|
||||||
|
constructor (api, app) {
|
||||||
|
this._api = api;
|
||||||
|
|
||||||
|
this.findVouchers(app);
|
||||||
|
}
|
||||||
|
|
||||||
|
async attachContract () {
|
||||||
|
const address = await Contracts.get().registry.lookupAddress('vouchfor');
|
||||||
|
|
||||||
|
if (!address || /^0x0*$/.test(address)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
const contract = await this._api.newContract(vouchForAbi, address);
|
||||||
|
|
||||||
|
return contract;
|
||||||
|
}
|
||||||
|
|
||||||
|
async findVouchers ({ contentHash, id }) {
|
||||||
|
if (!contentHash) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!contractPromise) {
|
||||||
|
contractPromise = this.attachContract();
|
||||||
|
}
|
||||||
|
|
||||||
|
const contract = await contractPromise;
|
||||||
|
|
||||||
|
if (!contract) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const vouchHash = await this.lookupHash(contract, `0x${contentHash}`);
|
||||||
|
const vouchId = await this.lookupHash(contract, id);
|
||||||
|
|
||||||
|
this.addVouchers(vouchHash, vouchId);
|
||||||
|
}
|
||||||
|
|
||||||
|
async lookupHash (contract, hash) {
|
||||||
|
const vouchers = [];
|
||||||
|
let lastItem = false;
|
||||||
|
|
||||||
|
for (let index = 0; !lastItem; index++) {
|
||||||
|
const voucher = await contract.instance.vouched.call({}, [hash, index]);
|
||||||
|
|
||||||
|
if (/^0x0*$/.test(voucher)) {
|
||||||
|
lastItem = true;
|
||||||
|
} else {
|
||||||
|
vouchers.push(voucher);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return vouchers;
|
||||||
|
}
|
||||||
|
|
||||||
|
@action addVouchers = (vouchHash, vouchId) => {
|
||||||
|
this.vouchers = uniq([].concat(this.vouchers.peek(), vouchHash, vouchId));
|
||||||
|
}
|
||||||
|
}
|
@ -30,6 +30,7 @@ class IdentityIcon extends Component {
|
|||||||
|
|
||||||
static propTypes = {
|
static propTypes = {
|
||||||
address: PropTypes.string,
|
address: PropTypes.string,
|
||||||
|
alt: PropTypes.string,
|
||||||
button: PropTypes.bool,
|
button: PropTypes.bool,
|
||||||
center: PropTypes.bool,
|
center: PropTypes.bool,
|
||||||
className: PropTypes.string,
|
className: PropTypes.string,
|
||||||
@ -84,7 +85,7 @@ class IdentityIcon extends Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
render () {
|
render () {
|
||||||
const { address, button, className, center, disabled, inline, padded, tiny } = this.props;
|
const { address, alt, button, className, center, disabled, inline, padded, tiny } = this.props;
|
||||||
const { iconsrc } = this.state;
|
const { iconsrc } = this.state;
|
||||||
const classes = [
|
const classes = [
|
||||||
styles.icon,
|
styles.icon,
|
||||||
@ -135,6 +136,7 @@ class IdentityIcon extends Component {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<img
|
<img
|
||||||
|
alt={ alt || address }
|
||||||
className={ classes }
|
className={ classes }
|
||||||
data-address-img
|
data-address-img
|
||||||
height={ size }
|
height={ size }
|
||||||
|
@ -18,7 +18,7 @@ import React, { Component, PropTypes } from 'react';
|
|||||||
import { connect } from 'react-redux';
|
import { connect } from 'react-redux';
|
||||||
import { bindActionCreators } from 'redux';
|
import { bindActionCreators } from 'redux';
|
||||||
|
|
||||||
import { fetchTokens } from '../../redux/providers/tokensActions';
|
import { fetchTokens } from '~/redux/providers/tokensActions';
|
||||||
import styles from './methodDecoding.css';
|
import styles from './methodDecoding.css';
|
||||||
|
|
||||||
class TokenValue extends Component {
|
class TokenValue extends Component {
|
||||||
|
@ -81,12 +81,11 @@ export function getTxOptions (api, func, _options, values = []) {
|
|||||||
options.to = options.to || func.contract.address;
|
options.to = options.to || func.contract.address;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!address) {
|
const promise = (!address)
|
||||||
return Promise.resolve({ func, options, values });
|
? Promise.resolve(false)
|
||||||
}
|
: WalletsUtils.isWallet(api, address);
|
||||||
|
|
||||||
return WalletsUtils
|
return promise
|
||||||
.isWallet(api, address)
|
|
||||||
.then((isWallet) => {
|
.then((isWallet) => {
|
||||||
if (!isWallet) {
|
if (!isWallet) {
|
||||||
return { func, options, values };
|
return { func, options, values };
|
||||||
|
@ -26,7 +26,6 @@ import HardwareStore from '~/mobx/hardwareStore';
|
|||||||
import ExportStore from '~/modals/ExportAccount/exportStore';
|
import ExportStore from '~/modals/ExportAccount/exportStore';
|
||||||
import { DeleteAccount, EditMeta, Faucet, PasswordManager, Shapeshift, Transfer, Verification } from '~/modals';
|
import { DeleteAccount, EditMeta, Faucet, PasswordManager, Shapeshift, Transfer, Verification } from '~/modals';
|
||||||
import { setVisibleAccounts } from '~/redux/providers/personalActions';
|
import { setVisibleAccounts } from '~/redux/providers/personalActions';
|
||||||
import { fetchCertifiers, fetchCertifications } from '~/redux/providers/certifications/actions';
|
|
||||||
import { Actionbar, Button, ConfirmDialog, Input, Page, Portal } from '~/ui';
|
import { Actionbar, Button, ConfirmDialog, Input, Page, Portal } from '~/ui';
|
||||||
import { DeleteIcon, DialIcon, EditIcon, LockedIcon, SendIcon, VerifyIcon, FileDownloadIcon } from '~/ui/Icons';
|
import { DeleteIcon, DialIcon, EditIcon, LockedIcon, SendIcon, VerifyIcon, FileDownloadIcon } from '~/ui/Icons';
|
||||||
|
|
||||||
@ -45,8 +44,6 @@ class Account extends Component {
|
|||||||
|
|
||||||
static propTypes = {
|
static propTypes = {
|
||||||
accounts: PropTypes.object.isRequired,
|
accounts: PropTypes.object.isRequired,
|
||||||
fetchCertifiers: PropTypes.func.isRequired,
|
|
||||||
fetchCertifications: PropTypes.func.isRequired,
|
|
||||||
setVisibleAccounts: PropTypes.func.isRequired,
|
setVisibleAccounts: PropTypes.func.isRequired,
|
||||||
|
|
||||||
account: PropTypes.object,
|
account: PropTypes.object,
|
||||||
@ -67,7 +64,6 @@ class Account extends Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
componentDidMount () {
|
componentDidMount () {
|
||||||
this.props.fetchCertifiers();
|
|
||||||
this.setVisibleAccounts();
|
this.setVisibleAccounts();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -90,11 +86,10 @@ class Account extends Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
setVisibleAccounts (props = this.props) {
|
setVisibleAccounts (props = this.props) {
|
||||||
const { params, setVisibleAccounts, fetchCertifications } = props;
|
const { params, setVisibleAccounts } = props;
|
||||||
const addresses = [params.address];
|
const addresses = [params.address];
|
||||||
|
|
||||||
setVisibleAccounts(addresses);
|
setVisibleAccounts(addresses);
|
||||||
fetchCertifications(params.address);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
render () {
|
render () {
|
||||||
@ -524,8 +519,6 @@ function mapStateToProps (state, props) {
|
|||||||
|
|
||||||
function mapDispatchToProps (dispatch) {
|
function mapDispatchToProps (dispatch) {
|
||||||
return bindActionCreators({
|
return bindActionCreators({
|
||||||
fetchCertifiers,
|
|
||||||
fetchCertifications,
|
|
||||||
newError,
|
newError,
|
||||||
setVisibleAccounts
|
setVisibleAccounts
|
||||||
}, dispatch);
|
}, dispatch);
|
||||||
|
@ -17,10 +17,8 @@
|
|||||||
import { pick } from 'lodash';
|
import { pick } from 'lodash';
|
||||||
import React, { Component, PropTypes } from 'react';
|
import React, { Component, PropTypes } from 'react';
|
||||||
import { connect } from 'react-redux';
|
import { connect } from 'react-redux';
|
||||||
import { bindActionCreators } from 'redux';
|
|
||||||
|
|
||||||
import { Container, SectionList } from '~/ui';
|
import { Container, SectionList } from '~/ui';
|
||||||
import { fetchCertifiers, fetchCertifications } from '~/redux/providers/certifications/actions';
|
|
||||||
import { ETH_TOKEN } from '~/util/tokens';
|
import { ETH_TOKEN } from '~/util/tokens';
|
||||||
|
|
||||||
import Summary from '../Summary';
|
import Summary from '../Summary';
|
||||||
@ -38,20 +36,9 @@ class List extends Component {
|
|||||||
orderFallback: PropTypes.string,
|
orderFallback: PropTypes.string,
|
||||||
search: PropTypes.array,
|
search: PropTypes.array,
|
||||||
|
|
||||||
fetchCertifiers: PropTypes.func.isRequired,
|
|
||||||
fetchCertifications: PropTypes.func.isRequired,
|
|
||||||
handleAddSearchToken: PropTypes.func
|
handleAddSearchToken: PropTypes.func
|
||||||
};
|
};
|
||||||
|
|
||||||
componentWillMount () {
|
|
||||||
const { accounts, fetchCertifiers, fetchCertifications } = this.props;
|
|
||||||
|
|
||||||
fetchCertifiers();
|
|
||||||
for (let address in accounts) {
|
|
||||||
fetchCertifications(address);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
render () {
|
render () {
|
||||||
const { accounts, disabled, empty } = this.props;
|
const { accounts, disabled, empty } = this.props;
|
||||||
|
|
||||||
@ -264,14 +251,7 @@ function mapStateToProps (state, props) {
|
|||||||
return { balances, certifications };
|
return { balances, certifications };
|
||||||
}
|
}
|
||||||
|
|
||||||
function mapDispatchToProps (dispatch) {
|
|
||||||
return bindActionCreators({
|
|
||||||
fetchCertifiers,
|
|
||||||
fetchCertifications
|
|
||||||
}, dispatch);
|
|
||||||
}
|
|
||||||
|
|
||||||
export default connect(
|
export default connect(
|
||||||
mapStateToProps,
|
mapStateToProps,
|
||||||
mapDispatchToProps
|
null
|
||||||
)(List);
|
)(List);
|
||||||
|
@ -84,7 +84,7 @@ describe('views/Signer/components/SignRequest', () => {
|
|||||||
expect(component).to.be.ok;
|
expect(component).to.be.ok;
|
||||||
});
|
});
|
||||||
|
|
||||||
describe.only('isMarkdown', () => {
|
describe('isMarkdown', () => {
|
||||||
it('returns true for markdown', () => {
|
it('returns true for markdown', () => {
|
||||||
const testMd = '# this is some\n\n*markdown*';
|
const testMd = '# this is some\n\n*markdown*';
|
||||||
const encodedMd = asciiToHex(unescape(encodeURIComponent(testMd)));
|
const encodedMd = asciiToHex(unescape(encodeURIComponent(testMd)));
|
||||||
@ -99,7 +99,7 @@ describe('views/Signer/components/SignRequest', () => {
|
|||||||
expect(isMarkdown(encodedMd)).to.be.true;
|
expect(isMarkdown(encodedMd)).to.be.true;
|
||||||
});
|
});
|
||||||
|
|
||||||
it('returns false for randow data', () => {
|
it('returns false for random data', () => {
|
||||||
expect(isMarkdown('0x1234')).to.be.false;
|
expect(isMarkdown('0x1234')).to.be.false;
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Parity ethkey WASM module."
|
description = "Parity ethkey WASM module."
|
||||||
name = "parity-ethkey-wasm"
|
name = "parity-ethkey-wasm"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Ethcore client."
|
description = "Ethcore client."
|
||||||
name = "ethcore-logger"
|
name = "ethcore-logger"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
|
@ -462,7 +462,7 @@
|
|||||||
<key>OVERWRITE_PERMISSIONS</key>
|
<key>OVERWRITE_PERMISSIONS</key>
|
||||||
<false/>
|
<false/>
|
||||||
<key>VERSION</key>
|
<key>VERSION</key>
|
||||||
<string>1.8.0</string>
|
<string>1.9.0</string>
|
||||||
</dict>
|
</dict>
|
||||||
<key>UUID</key>
|
<key>UUID</key>
|
||||||
<string>2DCD5B81-7BAF-4DA1-9251-6274B089FD36</string>
|
<string>2DCD5B81-7BAF-4DA1-9251-6274B089FD36</string>
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
<key>CFBundlePackageType</key>
|
<key>CFBundlePackageType</key>
|
||||||
<string>APPL</string>
|
<string>APPL</string>
|
||||||
<key>CFBundleShortVersionString</key>
|
<key>CFBundleShortVersionString</key>
|
||||||
<string>1.8</string>
|
<string>1.9</string>
|
||||||
<key>CFBundleVersion</key>
|
<key>CFBundleVersion</key>
|
||||||
<string>1</string>
|
<string>1</string>
|
||||||
<key>LSApplicationCategoryType</key>
|
<key>LSApplicationCategoryType</key>
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
!define COMPANYNAME "Parity"
|
!define COMPANYNAME "Parity"
|
||||||
!define DESCRIPTION "Fast, light, robust Ethereum implementation"
|
!define DESCRIPTION "Fast, light, robust Ethereum implementation"
|
||||||
!define VERSIONMAJOR 1
|
!define VERSIONMAJOR 1
|
||||||
!define VERSIONMINOR 8
|
!define VERSIONMINOR 9
|
||||||
!define VERSIONBUILD 0
|
!define VERSIONBUILD 0
|
||||||
!define ARGS "--warp"
|
!define ARGS "--warp"
|
||||||
!define FIRST_START_ARGS "ui --warp --mode=passive"
|
!define FIRST_START_ARGS "ui --warp --mode=passive"
|
||||||
|
@ -1201,6 +1201,7 @@ mod tests {
|
|||||||
Snapshots, VM, Misc, Whisper, SecretStore,
|
Snapshots, VM, Misc, Whisper, SecretStore,
|
||||||
};
|
};
|
||||||
use toml;
|
use toml;
|
||||||
|
use clap::{ErrorKind as ClapErrorKind};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn should_parse_args_and_flags() {
|
fn should_parse_args_and_flags() {
|
||||||
@ -1217,6 +1218,17 @@ mod tests {
|
|||||||
assert_eq!(args.arg_export_state_min_balance, Some("123".to_string()));
|
assert_eq!(args.arg_export_state_min_balance, Some("123".to_string()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn should_exit_gracefully_on_unknown_argument() {
|
||||||
|
let result = Args::parse(&["parity", "--please-exit-gracefully"]);
|
||||||
|
assert!(
|
||||||
|
match result {
|
||||||
|
Err(ArgsError::Clap(ref clap_error)) if clap_error.kind == ClapErrorKind::UnknownArgument => true,
|
||||||
|
_ => false
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn should_use_subcommand_arg_default() {
|
fn should_use_subcommand_arg_default() {
|
||||||
let args = Args::parse(&["parity", "export", "state", "--at", "123"]).unwrap();
|
let args = Args::parse(&["parity", "export", "state", "--at", "123"]).unwrap();
|
||||||
|
@ -13,4 +13,4 @@ hosts = ["all"]
|
|||||||
|
|
||||||
[ipfs]
|
[ipfs]
|
||||||
enable = false # this is the default
|
enable = false # this is the default
|
||||||
hosts = ["all"]
|
hosts = ["all"]
|
||||||
|
@ -3,4 +3,4 @@ chain = "dev"
|
|||||||
|
|
||||||
[mining]
|
[mining]
|
||||||
reseal_min_period = 0
|
reseal_min_period = 0
|
||||||
min_gas_price = 0
|
min_gas_price = 0
|
||||||
|
@ -8,4 +8,4 @@ hosts = ["all"]
|
|||||||
|
|
||||||
[ipfs]
|
[ipfs]
|
||||||
enable = false # this is the default
|
enable = false # this is the default
|
||||||
hosts = ["all"]
|
hosts = ["all"]
|
||||||
|
@ -28,4 +28,4 @@ cache_size = 256
|
|||||||
|
|
||||||
[misc]
|
[misc]
|
||||||
# Logging pattern (`<module>=<level>`, e.g. `own_tx=trace`).
|
# Logging pattern (`<module>=<level>`, e.g. `own_tx=trace`).
|
||||||
logging = "miner=trace,own_tx=trace"
|
logging = "miner=trace,own_tx=trace"
|
||||||
|
@ -4,4 +4,4 @@ port = 30305
|
|||||||
|
|
||||||
[rpc]
|
[rpc]
|
||||||
# JSON-RPC over HTTP will be accessible on port 8645.
|
# JSON-RPC over HTTP will be accessible on port 8645.
|
||||||
port = 8645
|
port = 8645
|
||||||
|
@ -537,21 +537,20 @@ macro_rules! usage {
|
|||||||
|
|
||||||
let matches = App::new("Parity")
|
let matches = App::new("Parity")
|
||||||
.global_setting(AppSettings::VersionlessSubcommands)
|
.global_setting(AppSettings::VersionlessSubcommands)
|
||||||
.global_setting(AppSettings::AllowLeadingHyphen) // allow for example --allow-ips -10.0.0.0/8
|
|
||||||
.global_setting(AppSettings::DisableHelpSubcommand)
|
.global_setting(AppSettings::DisableHelpSubcommand)
|
||||||
.help(Args::print_help().as_ref())
|
.help(Args::print_help().as_ref())
|
||||||
.args(&usages.iter().map(|u| Arg::from_usage(u).use_delimiter(false)).collect::<Vec<Arg>>())
|
.args(&usages.iter().map(|u| Arg::from_usage(u).use_delimiter(false).allow_hyphen_values(true)).collect::<Vec<Arg>>())
|
||||||
$(
|
$(
|
||||||
.subcommand(
|
.subcommand(
|
||||||
SubCommand::with_name(&underscore_to_hyphen!(&stringify!($subc)[4..]))
|
SubCommand::with_name(&underscore_to_hyphen!(&stringify!($subc)[4..]))
|
||||||
.about($subc_help)
|
.about($subc_help)
|
||||||
.args(&subc_usages.get(stringify!($subc)).unwrap().iter().map(|u| Arg::from_usage(u).use_delimiter(false)).collect::<Vec<Arg>>())
|
.args(&subc_usages.get(stringify!($subc)).unwrap().iter().map(|u| Arg::from_usage(u).use_delimiter(false).allow_hyphen_values(true)).collect::<Vec<Arg>>())
|
||||||
$(
|
$(
|
||||||
.setting(AppSettings::SubcommandRequired) // prevent from running `parity account`
|
.setting(AppSettings::SubcommandRequired) // prevent from running `parity account`
|
||||||
.subcommand(
|
.subcommand(
|
||||||
SubCommand::with_name(&underscore_to_hyphen!(&stringify!($subc_subc)[stringify!($subc).len()+1..]))
|
SubCommand::with_name(&underscore_to_hyphen!(&stringify!($subc_subc)[stringify!($subc).len()+1..]))
|
||||||
.about($subc_subc_help)
|
.about($subc_subc_help)
|
||||||
.args(&subc_usages.get(stringify!($subc_subc)).unwrap().iter().map(|u| Arg::from_usage(u).use_delimiter(false)).collect::<Vec<Arg>>())
|
.args(&subc_usages.get(stringify!($subc_subc)).unwrap().iter().map(|u| Arg::from_usage(u).use_delimiter(false).allow_hyphen_values(true)).collect::<Vec<Arg>>())
|
||||||
)
|
)
|
||||||
)*
|
)*
|
||||||
)
|
)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Parity JSON-RPC servers."
|
description = "Parity JSON-RPC servers."
|
||||||
name = "parity-rpc"
|
name = "parity-rpc"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
|
@ -82,9 +82,7 @@ impl<'a> Visitor<'a> for BlockNumberVisitor {
|
|||||||
_ if value.starts_with("0x") => u64::from_str_radix(&value[2..], 16).map(BlockNumber::Num).map_err(|e| {
|
_ if value.starts_with("0x") => u64::from_str_radix(&value[2..], 16).map(BlockNumber::Num).map_err(|e| {
|
||||||
Error::custom(format!("Invalid block number: {}", e))
|
Error::custom(format!("Invalid block number: {}", e))
|
||||||
}),
|
}),
|
||||||
_ => value.parse::<u64>().map(BlockNumber::Num).map_err(|e| {
|
_ => Err(Error::custom(format!("Invalid block number: missing 0x prefix"))),
|
||||||
Error::custom(format!("Invalid block number: {}", e))
|
|
||||||
}),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -112,9 +110,15 @@ mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn block_number_deserialization() {
|
fn block_number_deserialization() {
|
||||||
let s = r#"["0xa", "10", "latest", "earliest", "pending"]"#;
|
let s = r#"["0xa", "latest", "earliest", "pending"]"#;
|
||||||
let deserialized: Vec<BlockNumber> = serde_json::from_str(s).unwrap();
|
let deserialized: Vec<BlockNumber> = serde_json::from_str(s).unwrap();
|
||||||
assert_eq!(deserialized, vec![BlockNumber::Num(10), BlockNumber::Num(10), BlockNumber::Latest, BlockNumber::Earliest, BlockNumber::Pending])
|
assert_eq!(deserialized, vec![BlockNumber::Num(10), BlockNumber::Latest, BlockNumber::Earliest, BlockNumber::Pending])
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn should_not_deserialize_decimal() {
|
||||||
|
let s = r#""10""#;
|
||||||
|
assert!(serde_json::from_str::<BlockNumber>(s).is_err());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -74,13 +74,7 @@ impl<'a> Visitor<'a> for BytesVisitor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn visit_str<E>(self, value: &str) -> Result<Self::Value, E> where E: Error {
|
fn visit_str<E>(self, value: &str) -> Result<Self::Value, E> where E: Error {
|
||||||
if value.is_empty() {
|
if value.len() >= 2 && &value[0..2] == "0x" && value.len() & 1 == 0 {
|
||||||
warn!(
|
|
||||||
target: "deprecated",
|
|
||||||
"Deserializing empty string as empty bytes. This is a non-standard behaviour that will be removed in future versions. Please update your code to send `0x` instead!"
|
|
||||||
);
|
|
||||||
Ok(Bytes::new(Vec::new()))
|
|
||||||
} else if value.len() >= 2 && &value[0..2] == "0x" && value.len() & 1 == 0 {
|
|
||||||
Ok(Bytes::new(FromHex::from_hex(&value[2..]).map_err(|e| Error::custom(format!("Invalid hex: {}", e)))?))
|
Ok(Bytes::new(FromHex::from_hex(&value[2..]).map_err(|e| Error::custom(format!("Invalid hex: {}", e)))?))
|
||||||
} else {
|
} else {
|
||||||
Err(Error::custom("Invalid bytes format. Expected a 0x-prefixed hex string with even length"))
|
Err(Error::custom("Invalid bytes format. Expected a 0x-prefixed hex string with even length"))
|
||||||
@ -108,8 +102,7 @@ mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_bytes_deserialize() {
|
fn test_bytes_deserialize() {
|
||||||
// TODO [ToDr] Uncomment when Mist starts sending correct data
|
let bytes1: Result<Bytes, serde_json::Error> = serde_json::from_str(r#""""#);
|
||||||
// let bytes1: Result<Bytes, serde_json::Error> = serde_json::from_str(r#""""#);
|
|
||||||
let bytes2: Result<Bytes, serde_json::Error> = serde_json::from_str(r#""0x123""#);
|
let bytes2: Result<Bytes, serde_json::Error> = serde_json::from_str(r#""0x123""#);
|
||||||
let bytes3: Result<Bytes, serde_json::Error> = serde_json::from_str(r#""0xgg""#);
|
let bytes3: Result<Bytes, serde_json::Error> = serde_json::from_str(r#""0xgg""#);
|
||||||
|
|
||||||
@ -117,19 +110,12 @@ mod tests {
|
|||||||
let bytes5: Bytes = serde_json::from_str(r#""0x12""#).unwrap();
|
let bytes5: Bytes = serde_json::from_str(r#""0x12""#).unwrap();
|
||||||
let bytes6: Bytes = serde_json::from_str(r#""0x0123""#).unwrap();
|
let bytes6: Bytes = serde_json::from_str(r#""0x0123""#).unwrap();
|
||||||
|
|
||||||
// assert!(bytes1.is_err());
|
assert!(bytes1.is_err());
|
||||||
assert!(bytes2.is_err());
|
assert!(bytes2.is_err());
|
||||||
assert!(bytes3.is_err());
|
assert!(bytes3.is_err());
|
||||||
assert_eq!(bytes4, Bytes(vec![]));
|
assert_eq!(bytes4, Bytes(vec![]));
|
||||||
assert_eq!(bytes5, Bytes(vec![0x12]));
|
assert_eq!(bytes5, Bytes(vec![0x12]));
|
||||||
assert_eq!(bytes6, Bytes(vec![0x1, 0x23]));
|
assert_eq!(bytes6, Bytes(vec![0x1, 0x23]));
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO [ToDr] Remove when Mist starts sending correct data
|
|
||||||
#[test]
|
|
||||||
fn test_bytes_lenient_against_the_spec_deserialize_for_empty_string_for_mist_compatibility() {
|
|
||||||
let deserialized: Bytes = serde_json::from_str(r#""""#).unwrap();
|
|
||||||
assert_eq!(deserialized, Bytes(Vec::new()));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Ethcore stratum lib"
|
description = "Ethcore stratum lib"
|
||||||
name = "ethcore-stratum"
|
name = "ethcore-stratum"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Ethcore blockchain sync"
|
description = "Ethcore blockchain sync"
|
||||||
name = "ethsync"
|
name = "ethsync"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
description = "Parity Updater Service."
|
description = "Parity Updater Service."
|
||||||
name = "parity-updater"
|
name = "parity-updater"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
@ -3,7 +3,7 @@ description = "Ethcore utility library"
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "ethcore-util"
|
name = "ethcore-util"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@ description = "Ethcore IO library"
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "ethcore-io"
|
name = "ethcore-io"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
@ -3,7 +3,7 @@ description = "Ethcore network library"
|
|||||||
homepage = "http://parity.io"
|
homepage = "http://parity.io"
|
||||||
license = "GPL-3.0"
|
license = "GPL-3.0"
|
||||||
name = "ethcore-network"
|
name = "ethcore-network"
|
||||||
version = "1.8.0"
|
version = "1.9.0"
|
||||||
authors = ["Parity Technologies <admin@parity.io>"]
|
authors = ["Parity Technologies <admin@parity.io>"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
Loading…
Reference in New Issue
Block a user