Adrián Matejov
15df848b05
added Tezos support ( #302 )
...
* also added device tests for tezos
Signed-off-by: Adrian Matejov <adrian.matejov@simplestaking.com>
We also pushed signed operations to betanet network and they got accepted.
Here's the list of them
* transaction tz1 http://tzscan.io/ong8MQBX595Ld4dteHCbPqd6uzmEorEft6ZvfiX5vQMX4WHRh7K
* transaction tz2 http://tzscan.io/ooHZ2vbFX1M1fmr9KpLPWQ8r6oZB2RikpGBXsoQSZfbV1hWVjCP
* transaction tz3 http://tzscan.io/op79uLwaFqNB6SgcaAaJtoHFBQk3mL5bC1BQTvYzwX2DVSr8RJG
* origination tz1 http://tzscan.io/ooJg7qXtUjh16AtdSvv5kgaQnxjtAiBysFkG3EaG5qPAuDT1Cym contract http://tzscan.io/KT1VakcExcig27ZAuoLTExgGXtvUsykQSf5R
* origination tz2 http://tzscan.io/opDrUvCGUwKeu86b7GbRLeVzAkyKkdfnV9aSGAzGDLYYS11m6Qr contract http://tzscan.io/KT1LdQeHBSpvvzdRH495qHmtagavZcZ9Z5GW
* origination tz3 http://tzscan.io/opVWtfwvSvHzC6hsSGG31G23Q6nBov8SSvmA2nYXBNc5fWGk3Bg contract http://tzscan.io/KT1VfKfsgKFEfZ5vZUaZNaZyGrQf1gr1MEqr
* delegation tz1 http://tzscan.io/onws37YkYRnUvwYiPqYATZFtBVhBwbS2rdPkQjFGbAfLzt82MGa
* delegation tz2 http://tzscan.io/oocKfbotJwN5Zvmoybhb9LUJ6VhmeS42G2oZHaXQ2mXm98Rzx8r
* delegation tz3 http://tzscan.io/ooFQBcoMzwseJHnFgQ9fEPxAXhtgifuvvEH1CtmyAtnK5R7Drik
* transaction+reveal tz2 http://tzscan.io/ooEyN4FxP8RYh98RJgQxposDUuWHLWT8fUzWawNRCsMGxaNAN9c
* transaction+reveal tz3 http://tzscan.io/ooLaWQzZj1cbkMjZAifV71QCu5bdbMtET5CabrzLWQmnGMMhwmE
2018-09-10 16:40:31 +02:00
matejcik
cb4c366ce9
device_tests: add signtx expected responses generator
2018-09-10 16:02:17 +02:00
Pavol Rusnak
51f178ef1a
tests: cleanup CardanoGetPublicKey test
2018-09-07 19:22:57 +02:00
Tomas Susanka
ea77deeaed
tests: xfail marks removed
2018-09-07 17:21:41 +02:00
Tomas Susanka
5fadcb6b06
tests/ontology redundant swipe removed
...
This bug caused other tests (resetdevice_t2 in particular) to fail. This
is because the test made one more swipe than was supposed to. This led to
a failure in resetdevice tests, which do swipes as well and read data
returned, which did not fit due to the redundant swipe.
2018-09-07 16:33:16 +02:00
Pavol Rusnak
949438f4c5
tests: add script_type test to getpublickey test
2018-09-06 19:05:53 +02:00
Dušan Plavák
bd6bcf7dfa
Add network param to cardano sign tx ( #306 )
2018-09-06 17:25:55 +02:00
matejcik
305cb55d02
style: reformat client.py
2018-09-06 17:09:37 +02:00
Pavol Rusnak
434f279069
use implicit encoding in encode/decode
2018-09-06 16:22:38 +02:00
Matus Zamborsky
21326d3a41
add Ontology support ( #301 )
...
* add Ontology support
Signed-off-by: Matus Zamborsky <zamborsky@gmail.com>
2018-09-06 15:36:44 +02:00
Tomas Susanka
4f572f9e15
cardano: remove sign/verify functions
2018-09-06 14:54:06 +02:00
matejcik
351c017583
style: more known_third_party modules
...
because frankly, isort's detection is a huge mess
2018-09-05 15:43:29 +02:00
Pavol Rusnak
555bb62e3f
btc: add script_type to get_public_node
2018-09-05 15:21:11 +02:00
Dušan Plavák
fb22b894ba
Add cardano support to trezorctl and some tests ( #300 )
...
Add cardano support to trezorctl and some tests
2018-09-05 14:56:31 +02:00
Tomas Susanka
6c15a41514
tests: ripple fix
2018-09-05 10:42:32 +02:00
matejcik
80766ca6b3
tests: xfail Stellar on T1 until we re-enable it
2018-09-04 16:14:29 +02:00
matejcik
d235875e5e
build: support new tooling in trezor-common
2018-09-04 15:51:38 +02:00
matejcik
e5c2329b80
client: drop stellar_get_public_key from compatibility links
2018-09-04 15:51:38 +02:00
matejcik
1de1ff2823
tx_api: fix issue on python < 3.5
2018-09-03 14:59:39 +02:00
matejcik
0f71cbcc44
tx_api: update to assume "/api" path again, let blockHash request be
...
cached
2018-09-03 14:59:29 +02:00
Tomas Susanka
88a02822d3
stellar: public key methods removed
2018-09-03 14:57:10 +02:00
Pavol Rusnak
3c48f906b2
tests: fix eip155 test
2018-09-03 14:53:53 +02:00
HackyMiner
5a4c37d41c
add more eip155 test cases ( #297 )
2018-09-03 14:52:57 +02:00
matejcik
88b50ac2ff
style: add makefile with style targets, final touchups
2018-08-21 16:30:22 +02:00
matejcik
e2d45397d4
device_tests: smarter device selection
...
skips bridge, dies somewhat more cleanly when no device found
2018-08-21 16:06:18 +02:00
matejcik
abf0e82d80
trezorlib: implement auto-creating protobuf messages from dicts
...
along with a convert_dict function to rename keys from camelCase
and optionally apply simple field renames
2018-08-21 16:02:15 +02:00
matejcik
f05f9a2b37
nem: make a clearer flow for create_sign_tx
2018-08-21 15:57:50 +02:00
matejcik
3d3e9b67b4
style: apply black/isort
2018-08-13 18:22:19 +02:00
matejcik
e336f578af
device_tests: update test_msg_getentropy to new style
2018-08-13 15:49:12 +02:00
matejcik
29f928e4f2
style: bare excepts, left-over bad imports
2018-08-10 16:05:14 +02:00
matejcik
5259146a0b
style: remove unused imports with autoflake
2018-08-10 15:48:39 +02:00
matejcik
ca608d0a98
flake8: fix complaints (for the last time, hopefully)
2018-08-10 15:24:21 +02:00
matejcik
6029a98414
debuglink: fix bug in self_test bootloader detection
2018-08-10 15:18:34 +02:00
matejcik
4b4469b9f4
tests: clean up usage of hardening constants
2018-08-10 14:37:49 +02:00
matejcik
c0ef1ec535
tests: use new API
2018-08-10 14:04:58 +02:00
matejcik
d5dee0c897
trezorlib: move mostly-debug methods from device to debuglink
2018-08-10 13:33:14 +02:00
matejcik
65d8adb0be
trezorlib: rename device.*_device to device.*
2018-08-10 13:32:50 +02:00
matejcik
a3d560529c
trezorlib: post-merge updates
2018-08-06 16:15:44 +02:00
matejcik
2bb7088281
Merge branch 'master' into matejcik/client-split
2018-08-06 16:13:04 +02:00
D.Matskevych
5a677c3782
Added Zencash supporting
2018-07-26 11:34:51 +02:00
Pavol Rusnak
9462601849
tests: extract eip155 tests for ethereum, add more cases
2018-07-19 18:06:56 +02:00
Tomas Susanka
2a5ca12924
ripple: fix invalid fee test
2018-07-13 13:25:43 +02:00
matejcik
5b49658c8b
ripple: fix broken fail-test
2018-07-12 16:56:47 +02:00
Tomas Susanka
61e63c6a02
ripple: ripple prefix dropped in functions
2018-07-12 16:36:33 +02:00
Tomas Susanka
c0f29bf4fd
ripple: proper sign_tx command
2018-07-12 16:36:33 +02:00
Tomas Susanka
37847fb56f
ripple: client functions moved to ripple.py
2018-07-12 16:36:33 +02:00
Tomas Susanka
77414ad761
ripple: code review fixes
2018-07-12 16:36:33 +02:00
Tomas Susanka
2017dadfcb
ripple: sign tx command including tests
2018-07-12 16:36:33 +02:00
Tomas Susanka
147e7e21cb
ripple: get address command including tests
2018-07-12 16:36:33 +02:00
Tomas Susanka
8348d47fd7
stellar/tests: T2 support merged -> xfail dropped
2018-07-12 15:21:46 +02:00
Tomas Susanka
e5cdf45956
stellar/tests: some device tests set show_display=True
2018-07-11 16:03:38 +02:00
matejcik
87837bc305
stellar: drop protocol_version
2018-07-09 14:06:11 +02:00
matejcik
7083eb7a5c
trezorlib: drop @field decorator
...
its function is replaced by @expect(field="name") -- it doesn't make sense
to use @field without @expect anyway
2018-07-09 13:57:30 +02:00
matejcik
00617817c3
trezorlib: disable encrypt/decrypt message functionality
...
it is disabled in Trezors and its utility is unclear
2018-07-09 13:56:22 +02:00
matejcik
7e90e89e69
client: get rid of TrezorClient._convert_prime
2018-07-09 13:56:22 +02:00
matejcik
23b58cc0cb
flake8: fix complaints
2018-07-09 13:56:22 +02:00
matejcik
f3a042db80
trezorlib: split out methods from ProtocolMixin
2018-07-09 13:56:22 +02:00
matejcik
1820f529fc
trezorlib: shuffling things from client
2018-07-09 13:50:25 +02:00
matejcik
2f3a32f8e8
trezorlib: drop support for EncryptMessage and DecryptMessage
2018-07-09 13:46:18 +02:00
matejcik
19a0f4cc7b
tx_api: support blockbook, allow url-less operation
...
Bitcoin Testnet backends were removed.
This broke our tests that work purely on local data but nevertheless
need to know backend URLs. Because the design is less than ideal.
Here, we do a little cleanup:
* blockbook URLs are respected
* Dogecoin is now supported by our blockbook backend so we don't need
a special tx-api implementation
* it's possible to instantiate a TxApi that is backed by the cache,
without a known URL
* relevant tests now make use of this feature
2018-07-09 13:46:18 +02:00
matejcik
85a32d01b9
build: do not import trezorlib in setup.py, parse out __version__
by hand
...
also update path to coin generating tool
2018-07-09 13:46:18 +02:00
matejcik
6f23331dfc
build: remove prebuilt protobuf files
...
Also clean out .gitignore a little while we're at it
2018-07-09 13:46:18 +02:00
matejcik
ad16588171
stellar: update T1 tests
2018-06-28 12:40:49 +02:00
ZuluCrypto
b2f35de8b8
stellar.py - do not alias trezorlib.messages import to "proto"
2018-06-28 11:57:56 +02:00
ZuluCrypto
cd7189839c
stellar - return addresses as utf-8 strings
2018-06-28 11:57:56 +02:00
ZuluCrypto
2549eaf5a6
test_stellar.py - split imports into two lines and do not alias messages to "proto"
2018-06-28 11:57:56 +02:00
ZuluCrypto
05afd986c1
test_stellar.py - fix style issues
2018-06-28 11:57:56 +02:00
ZuluCrypto
af38407a43
stellar - add unit tests for parsing XDR
2018-06-28 11:57:56 +02:00
ZuluCrypto
96f0801b90
stellar.py - fix missing destination_amount when parsing path payment
2018-06-28 11:57:56 +02:00
ZuluCrypto
dd324a99c5
stellar.py - fix mising str() cast on type
2018-06-28 11:57:56 +02:00
ZuluCrypto
8a284c03d1
stellar.py - fix incorrect constants
2018-06-28 11:57:56 +02:00
ZuluCrypto
4628327789
fix comment
2018-06-28 11:57:56 +02:00
ZuluCrypto
188178a438
stellar - add test for setting inflation destination
2018-06-28 11:57:56 +02:00
ZuluCrypto
6afaa41616
stellar - _xdr_read_address now returns string instead of bytes
2018-06-28 11:57:56 +02:00
Pavol Rusnak
cc6cc49999
tests: re-enable Stellar for T1
2018-06-27 17:42:11 +02:00
Tomas Susanka
5f73976893
stellar: note on BIP-32 usage; address test with Stellar's official test vectors
2018-06-26 11:52:47 +02:00
matejcik
201297a1f9
tests: close debuglink in fixture-based tests
2018-06-22 14:18:18 +02:00
Pavol Rusnak
3c1456939c
tests: update test_cancel to test using Initialize
2018-06-22 13:28:32 +02:00
matejcik
f9f79b745c
Merge branch '0.10.x'
2018-06-22 13:19:28 +02:00
matejcik
b7cbbba6a7
release: bump version to 0.10.2
2018-06-21 16:50:38 +02:00
matejcik
54f1599a5a
regenerate license headers
...
This clarifies the intent: the project is licenced under terms
of LGPL version 3 only, but the standard headers cover only "3 or later",
so we had to rewrite them.
In the same step, we removed author information from individual files
in favor of "SatoshiLabs and contributors", and include an AUTHORS
file that lists the contributors.
Apologies to those whose names are missing; please contact us if you wish
to add your info to the AUTHORS file.
2018-06-21 16:49:13 +02:00
Tomas Susanka
10bbb57c86
tests/device: stellar accounts are addresses
2018-06-20 15:58:13 +02:00
Pavol Rusnak
44ac7656b4
vendor: update trezor-common; regenerate protobuf
2018-06-20 15:57:35 +02:00
Pavol Rusnak
b1eae58884
tests: disable Stellar tests for T1 too
2018-06-20 00:13:34 +02:00
Pavol Rusnak
3f93b28fe4
device_tests: fix test_msg_signtx_zcash
2018-06-15 10:35:28 +02:00
Tomas Susanka
ebe41c69f8
tests/stellar: trezor core currently throws Firmware err
2018-06-13 13:40:58 +02:00
Pavol Rusnak
015d72102d
device_tests: add failing tests for stellar
2018-06-11 19:22:16 +02:00
matejcik
cf661a8196
Merge branch 'fix-0.10.1'
2018-06-11 19:05:32 +02:00
Pavol Rusnak
1477c9aa9e
trezorctl/trezorlib: add show_display to StellarGetAddress/StellarGetPublicKey
2018-06-11 18:55:52 +02:00
matejcik
77361e563d
release: bump version and changelog for 0.10.1
2018-06-11 18:51:16 +02:00
Tomas Susanka
22872c53c2
tests/stellar: missing field annotation
2018-06-11 18:42:23 +02:00
Tomas Susanka
d3d9ceb0c4
tests: stellar test for get address
2018-06-11 18:42:23 +02:00
Tomas Susanka
c0a823ca1c
protobuf: stellar get address
2018-06-11 18:42:23 +02:00
matejcik
741f264a2f
release: bump version and add date to changelog
2018-06-08 16:07:46 +02:00
matejcik
d2021fd8a2
ckd_public: restore as a deprecation wrapper
...
(because older versions of electrum will still require it)
2018-06-07 17:07:20 +02:00
matejcik
73f016c465
trezorctl: update firmware_update to work better with TT ( fix #269 )
...
This removes the --erase option which was fishy before (and is now superseded
by wipe_device in bootloader mode).
Also adds a draft of "local fingerprint check" functionality for T1. This will
be expanded to work with TT in future releases.
2018-06-07 17:06:31 +02:00
Tomas Susanka
63222931be
tests/device: nem is not xfail anymore
2018-06-07 14:41:47 +02:00
matejcik
e110d87494
protobuf: update trezor-common and regenerate
2018-06-07 14:07:26 +02:00
Aleksey Popov
922748e348
lisk: restore Lisk sign and verify message functionality
2018-06-07 14:07:26 +02:00
Pavol Rusnak
9238382435
tests: update test_msg_signtx_zcash
2018-06-06 16:42:58 +02:00
Pavol Rusnak
21670b8226
tests: update zcash test
2018-06-05 17:20:38 +02:00
Pavol Rusnak
e4dcc8d8c6
zcash overwinter support
2018-06-05 16:05:14 +02:00
matejcik
cd3559b419
tests: rename test_cancel after it was parametrized
2018-06-05 13:11:24 +02:00
matejcik
269eaa298f
tests: make a fixture out of client
...
also implement Cancel tests
2018-06-05 13:08:54 +02:00
ZuluCrypto
7673ebf952
stellar - add additional tests and instructions for calculating signature
2018-06-05 11:59:48 +02:00
Pavol Rusnak
17479f26a7
device_tests: re-enable decred test for T1
2018-06-02 15:53:22 +02:00
Pavol Rusnak
5e14a5f059
device_tests: cashaddr test in sign/verify message
2018-06-01 21:30:05 +02:00
Pavol Rusnak
1a642713a5
Revert "device_tests: update test_bip32_speed cache-speed ratio to 1.2x"
...
This reverts commit 2ab4751dcb
.
2018-05-30 12:44:39 +02:00
Pavol Rusnak
61f5bbca91
vendor: update trezor-common
2018-05-30 11:31:12 +02:00
Pavol Rusnak
d4b17c5b36
device_tests: fix bitcore entry in coins.py
2018-05-30 10:50:49 +02:00
Pavol Rusnak
0d6ac99bf5
device_tests: fix bgold unit test
2018-05-29 17:33:18 +02:00
matejcik
279da34864
Merge branch 'matejcik/refactor'
2018-05-28 17:52:01 +02:00
matejcik
5191fd09be
device_tests: add a compat test for cosi, checking interoperability between Trezor and local implementation
2018-05-28 17:41:52 +02:00
Pavol Rusnak
2ab4751dcb
device_tests: update test_bip32_speed cache-speed ratio to 1.2x
2018-05-28 16:58:42 +02:00
matejcik
8410151810
remove remaining usages of expand_path
2018-05-28 15:47:57 +02:00
matejcik
c10c3f7fd9
stellar: better way to handle default path
...
(maybe do this for other currencies too?)
2018-05-28 15:47:40 +02:00
matejcik
aace6577c8
log: remove special handling of Features/CoinType in prettyprinter
...
now that Trezor won't send CoinTypes anymore
2018-05-28 15:01:17 +02:00
matejcik
99bc267301
client: hide uninteresting functions from test tracebacks
2018-05-28 14:45:54 +02:00
matejcik
2bf34dc4b4
unit_tests: added test suite for Ed25519 and CoSi
...
It's rather slow so it's disabled by default.
Use `pytest -m slow_cosi` to run.
2018-05-28 14:20:45 +02:00
matejcik
a0f73b726d
cosi: typehints, documentation, removed selftest
2018-05-28 14:20:26 +02:00
matejcik
0e8fe9e743
ed25519: type hints
2018-05-28 14:17:11 +02:00
Pavol Rusnak
648ef511b6
device_tests: use original ethereum message digest, enable ethereum_{sign,verify}message for T2
2018-05-25 14:23:16 +02:00
matejcik
2fdb5cd538
cosi: publish "pubkey from privkey" operation from ed25519
2018-05-25 13:12:42 +02:00
matejcik
886e269e2f
trezorlib: mark ed25519 impl as private
2018-05-25 13:07:02 +02:00
Tomas Susanka
f273bbb736
tests/device/stellar: assert pubkey, address comment
2018-05-25 12:01:07 +02:00
matejcik
9982ef98f9
Merge branch 'master' into matejcik/refactor
2018-05-24 19:18:26 +02:00
matejcik
e779a251fb
transport: better ways to handle errors when enumerating devices
2018-05-24 19:14:05 +02:00
matejcik
97fa4670ac
transport: add message logging to bridge
2018-05-24 18:08:50 +02:00
Pavol Rusnak
e2962ef9f7
fix typo
2018-05-24 17:07:17 +02:00
Pavol Rusnak
bb5e49e452
device_tests: fix failed test
2018-05-24 17:02:11 +02:00
Pavol Rusnak
b67322be2f
device_tests: enable cashaddr tests (msg_getaddress, signtx_bcash) for T2
2018-05-24 16:40:27 +02:00
matejcik
17b37034e8
device_tests: fix test_msg_recoverydevice for T1
2018-05-23 17:08:16 +02:00
matejcik
f8f0be9c86
device_tests: fix T1 test differences in wording
2018-05-23 16:54:24 +02:00
matejcik
f2aee59e27
device_tests: do not xfail Lisk tests, they are now merged
2018-05-23 14:21:24 +02:00
matejcik
4b7926268e
drop Lisk and Stellar sign/verify message functionality
2018-05-23 14:20:54 +02:00
matejcik
70172520fb
protobuf: update messages from upstream.
...
This drops sign/verify messages for Lisk and Stellar so we have to
remove the corresponding methods.
2018-05-23 14:04:09 +02:00
Jan Pochyla
bc27089546
tests: remove lisk sign/verify
2018-05-23 13:16:14 +02:00
matejcik
ce7ee8ae30
device_tests: mark decred
2018-05-22 20:12:51 +02:00
matejcik
2225343c52
device_tests: in test_multisig, T1 raises a different message
...
expected: "Pubkey not found in multisig script"
actual: "signing.c:780:Pubkey not found in multisig script"
2018-05-22 20:12:51 +02:00
matejcik
013e0f6d66
device_tests: get nicer tracebacks by using pytest.raises instead of custom exception code
2018-05-22 20:12:51 +02:00
matejcik
224e3c18f5
device_tests: fix test_protection_levels for T1
...
a couple expected ButtonRequests were missing
2018-05-22 20:12:45 +02:00
matejcik
a4fe17b461
device_tests: xfail for decred. This should be investigated more though.
2018-05-22 17:51:41 +02:00
matejcik
465c01d4f7
device_tests: add more currency markers
...
missed Stellar tests, plus Ethereum, for good measure
2018-05-22 17:29:03 +02:00
matejcik
af98a4071a
device_tests: allow custom runxfail
...
We can now selectively runxfail certain tests. This is useful for
accepting PRs into trezor-core:
1. trezor-core is going to get a pytest.ini that sets xfail_strict.
That means that if an `xfail`ed test actually passes, that will
break the test suite. So it will be visible when we implement
a feature for which tests exist.
2. To allow PRs to pass the test suite without touching python-trezor
directly, we add a new pytest.ini option: run_xfail.
This adds a list of markers which will ignore `xfail`.
So:
2.1 First, the python-trezor PR marks the tests with the name
of the feature. This commit already does that: Lisk tests
are marked `@pytest.mark.lisk`, NEMs are `@pytest.mark.nem`,
etc.
The tests will be also marked with `xfail`, because the
feature is not in core yet.
2.2 Then, the trezor-core PR implements the feature, which makes
the `xfail`ed tests pass. That breaks the test suite.
2.3 To fix the test suite, the core PR also adds a `run_xfail`
to `pytest.ini`: `run_xfail = lisk`.
(it can take a list: `run_xfail = lisk nem stellar`)
That will make the test suite behave as if the tests are not
`xfail`ed. If the feature is implemented correctly, the tests
will pass.
2.4 When the PR is accepted to core, the next step should be
a PR to python-trezor that removes the `xfail`s. After that,
we should also remove the `run_xfail` option, just to be tidy.
2018-05-22 17:29:03 +02:00
Tomas Susanka
e656bbf072
stellar: xdr parse move to trezorctl; client works with messages
2018-05-17 17:17:09 +02:00
matejcik
db92b13f97
cosi: move things around
...
ed25519raw is moved back to trezorlib
ed25519cosi is renamed to cosi, and has a couple more functions,
with the expectation that TrezorClient.cosi_* methods will move there.
Also most code shouldn't need ed25519raw for anything, so it might get
renamed to "_ed25519" to indicate that it's a private implementation.
For now, I added a "verify" method to cosi, so that you don't need to
call into ed25519raw.checkvalid. But trezor-core's keyctl is also
using ed25519raw.publickey. I'm not sure if that's worth replicating
in cosi, or whether to just leave it be, so I'm leaving it be for now.
Importantly, new function "sign_with_privkey" does that math thing that
was part of the selftest and is also explicitly listed in keyctl.
(it's called sign_with_privkey because I expect to have a "sign" method
here that calls into Trezor)
2018-05-17 12:53:01 +02:00
Tomas Susanka
277296be90
tests/stellar: verify marked as not passing on T2
2018-05-16 15:04:00 +02:00
Tomas Susanka
3ee3083e8c
tests/device/stellar: verify message
2018-05-14 16:53:10 +02:00
Tomas Susanka
bb74950e23
stellar: message is normalized before sign/verify
2018-05-14 15:33:57 +02:00
Tomas Susanka
22560128fe
stellar: StellarSignMessage.message is bytes
2018-05-14 15:17:13 +02:00