Try   HackMD

NEM - Harlock Hardfork Details


NOTE

The Harlock hardfork will be executed at block height 3,464,800. ETA: around 18 Nov 2021, 6:00pm UTC


Purpose

The "Harlock" hardfork for NEM is intended for users to explicitly signal support for the integration of NEM as a dedicated subChain of Symbol, as proposed here. It does so by burning all of the current NEM 'core funds', and minting new funds into a new 5-of-7 multisig account, with four cosigners from Valkyrie and three core developers.

At and after the Harlock hardfork, all outflows from the following fee sink accounts will be prohibited:

Overview

                                             ┌────────────────┐
                                             │   Does 51% of  │
      ┌──────────Retry─Fork─────────────────►│  harvesting    │
      │                                      │ power upgrade? │
      │                                      └──┬────────┬────┘
      │                                         │        │
      │                  ┌──────────────┐       │        │        ┌───────────────┐
      │                  │ Do any       │      Yes      No        │ Fork Fails    │
      │                  │ burned funds │◄──────┘        └───────►│               │
      │                  │ move before  │                         │ Trust retains │
      │                  │ fork?        │                         │   control!    │
      │                  └──┬───────┬───┘                         └───────────────┘
┌─────┴──────────┐          │       │
│ Fallback  txes │         Yes      No       ┌────────────────┐
│  are included  │◄─────────┘       └───────►│ Preferred txes │
│  in fork block │                           │  are included  │
│                │                           │  in fork block │
│ Trust retains  │                           │                │
│   control      │                           │ Core devs and  │
└────────────────┘                           │ Valkyrie are   │
                                             │ in control!    │
                                             └────────────────┘

Step Zero: Definitions/Preparation

New Protocol Fund: Prior to the fork, one new (empty) multisig accounts will need to be created. All newly minted protocol funds will be transfered into this.

NemesisII Treasury reissuance fork block.

NemesisII Fork Block

At the fork block, a set of predefined TransferTransactions will be sent to the network and harvested by upgraded nodes (v0.6.98). They will be predefined in configuration [1] and will revoke XYM tokens from Trust and NxL owned accounts. In addition, TransferTransactions will be issued from the Nemesis block to the new accounts.

[1] The hashes of these special transactions will be listed in the nis.treasuryReissuanceForkTransactionHashes property.

Harvesting Changes (TEMPORARY)

DefaultNewBlockTransactionsProvider:getBlockTransactions

At NemesisII height, retrieve all transactions from UTCache that have a hash in nis.treasuryReissuanceForkHeight and order them by TimeStamp. Since there is no state hash, we don't have to worry about corrupting it.

DefaultUnconfirmedState.verifyAndValidate

When a transaction is added to the UTCache, its signature is checked. Bypass this check for any transactions with a hash in nis.treasuryReissuanceForkTransactionHashes

Block Processing Changes

NemesisSinkValidator

Currently, this validator ensures that signatures from the Nemesis Account are only allowed in the Nemesis block.

This validator will need to be weakened to allow Nemesis Account signatures in both Nemesis and NemesisII block.

MinimumFeeValidator

NIS does not currently perform full validation on the Nemesis block, so this validator does not properly handle nemesis originating transactions. It needs to be modified to change minimum allowable fee for nemesis originating transactions to zero.

ReclaimFundsForkTransactionBlockValidator (TEMPORARY)

Validates that the block at height nis.treasuryReissuanceForkHeight contains exactly all transactions in nis.treasuryReissuanceForkTransactionHashes. This will cause a stall until the special transactions are included.

BlockChainValidator::verifyTransactions

Update verification to skip transactions with hashes in nis.treasuryReissuanceForkTransactionHashes. This will have some negative performance impact because it will result in an extra hash per transaction.

Fee Sink Handling

FeeSinkNonOperationalValidator

Since both the namespace and mosaic rental fees sinks are multisig transactions, a new MultsigTransaction validator can inspect the transaction's other transaction signer address. If this address matches one of the fee sink accounts, the transaction will be rejected.

Safety Valve

If any of the funds being burned are moved between the release and the NemesisII block, the fork will fail. In order to prevent a catastrophic failure in this case, a set of special fallback transactions [2] can be sent to the network to prevent a catastrophic failure. In the case of failure, the fork could be reattempted at a later date.

[2] The hashes of these transactions are specified in the nis.treasuryReissuanceForkFallbackTransactionHashes configuration property.

Appendix: Account Mappings

New Protocol Treasury Account: NCHESTYVD2P6P646AMY7WSNG73PCPZDUQNSD6JAK

       NEM Group Trust Addresses
      ┌──────────────────────────────────────────────────────────────────┐
      │  1. NBLOCKYZLCBVO2XF2DB3D74AE2RC5WSHX5JEZOID   1167024434.306550 │
      │  2. NANODESTSN7GU76QPLGMJ7BCGCAA2PHVBZZUUI62     10583640.541000 │
      │  3. NCPAYOUTH2BGEGT3Q7K75PV27QKMVNN2IZRVZWMD      3213957.350100 │
      │  4. NBKXLNQ2GKTLQBTXNFOHULNJDA7T2Q57CZGQ2TFP    208998360.823780 ├──────────────────┐
      │  5. NATRUSTUAB5LAWDSOWDUPQUFYRTGZTJZDGML2JKP   1399339585.654040 │                  │
      └──────────────────────────────────────────────────────────────────┘                  │
                                                                                            │
       NEM Group Limited Addresses                                                          │
      ┌──────────────────────────────────────────────────────────────────┐                  │
      │  6. NB2MQ7EA2YG2RRXHIHO4HA2WCYUYCX5BDQG5CQNW     10472248.595466 │                  │
      │  7. NDBRF5NM466LB6CINFIXLGRIGDL36L7B667WMVQ5       844475.303954 ├──────────────────┤
      │  8. NBRXCR7QJ56CTX5HMIP7VHDMYZTYCEN3DZAIK6O4            3.350000 │                  │
      └──────────────────────────────────────────────────────────────────┘                  │
                                                                                            │
       NEM Ventures Limited Addresses                                                       │
      ┌──────────────────────────────────────────────────────────────────┐                  │
      │  9. NDYNZWZ66ZKBSROL63Y5A27QQEACACT46P5QEUIU     99874634.541950 │                  │
      │ 10. NBVEMLRQUWTFKOIBU5FBBNTA437S27EUC2H7CIL3      7934610.785334 │                  │
      │ 11. NC2M77ZXJ5FEWJUD4VQRGNJPIGFGCMXYL4FNMNUN            1.428776 ├──────────────────┤
      │ 12. NDEBESTILI7WL4PJOY5QXIUXHVOYWW3TL6KCSFI4          109.782000 │                  │
      └──────────────────────────────────────────────────────────────────┘                  │
                                                                                            │
       NEM Holdings Limited Addresses                                                       │
      ┌──────────────────────────────────────────────────────────────────┐                  │
      │ 13. NDSQUAFDFXI4CCNZXQNH3MNMOISYGSAVEODUTJBA      4896576.095100 ├──────────────────┤
      └──────────────────────────────────────────────────────────────────┘                  │
                                                                                            │
       Continuity Fund Addresses                                                            │             NEM Protocol Treasury Funds
      ┌──────────────────────────────────────────────────────────────────┐                  │            ┌─────────────────────────────────────────────────────────────┐
      │ 14. NCONTINUYJDHQ676U7OOASO42I4IJXHZD4O3BTAR     34968242.347680 ├──────────────────┼────────────► NCHESTYVD2P6P646AMY7WSNG73PCPZDUQNSD6JAK  2971608400.5534204 │
      └──────────────────────────────────────────────────────────────────┘                  │            └─────────────────────────────────────────────────────────────┘
                                                                                            │
       Miscellaneous Addresses + Dust                                                       │
      ┌──────────────────────────────────────────────────────────────────┐                  │
      │ 15. NC2EYJ2R4SRG6QC5H4B65IFKLXGBFBS2MBUDGFF6     11656924.347752 │                  │
      │                                                                  │                  │
      │ 16. NCMARKECQXP3SQZSJPCBKOQWIXRRI7LIS4FTU4VZ           11.700000 │                  │
      │ 17. NCONTRLFKPO6YVXO5WUIJ4SWSCSKBJIPV456RSCL            5.850000 │                  │
      │ 18. NCOPERAWEWCD4A34NP5UQCCKEX44MW4SL3QYJYS5            1.050000 │                  │
      │ 19. NDEVPRE5ZWVG2PXSM54BGZBFF525G24UKVOGOZNT            5.850000 │                  │
      │ 20. NDEVPOSK4OMR4PRTLYFHX4W5QTOND7TZDT2DTU4Q           11.700000 │                  │
      │ 21. NAFUNDBUKIOSTMD4BNXL7ZFE735QHN7A3FBS6CMY           14.700000 │                  │
      │ 22. NAFUNDCJBFWXJWQZITUJOIW4O3E6YHQYQYSISPVA           17.550000 │                  │
      │ 23. NAFUNDDWQUHMIKPV2JUH2VNCYEAQX3O7QKHECZUV           35.100000 │                  │
      │ 24. NAFUNDAFO2MHWRR446YHADKR43XQBDJGWFRTMICH           11.700000 │                  │
      │ 25. NAFUNDEULL67VO7WCJBGBHCLCMD5KEH5EI7G5SGR           38.150000 │                  │
      │ 26. NAFUNDFE4HIZWV36FKGFXFFHG5SMUH2XVEEKE4ZD           23.400000 │                  │
      │ 27. NAFUNDHZWSIV4ARXSGGSFONCGFGYTLCB7VOT53SR            3.750000 │                  │
      │ 28. NALMPEMFS3HDXGFHO6AFGLUPMZOPDQMUWZWXBJS5           17.550000 │                  │
      │ 29. NB6T2NT4WVMS2THDZRLPCKVU636BUJ2V7E5DZX7X        91009.200000 │                  │
      │ 30. NALOG6DAIJ7LYWLGY73AT3OWS5ORYJ27WNBI6MHP            0.500000 │                  │
      │ 31. NAFOUND54A2777TVS2IJ733WO6SYQWMXC3AIHOBO            5.300000 │                  │
      │ 32. NAUSCHA55DLLJRBJPFU3V3ZHK3NY6KSI3P46WXCL            5.300000 ├──────────────────┘
      │ 33. NANACHZH3EDZFJOEFL7UGK4VD3IKGAL6DGFI6TKL            1.700000 │
      │ 34. NAMECHPLF5YGZZSWCVMSZ6ZU5U3EGIKI3CBRBTKD            0.400000 │
      │ 35. NALAMCHMVVHN427NG4GGEYFQ7S7EZX7DPV4VPOL3            0.500000 │
      │ 36. NACNCH4ZUTJRTCBBLFCNCEUOCEQ2JLEZYG6HKZ3N            0.350000 │
      │ 37. NASEACHB4GDLNLC2EGU7KQB3T2WY23UWTNVUSLKH            5.050000 │
      │ 38. NAANZCHVAM5RXTKFNG7U6BFBUIOHDZHPF4IRRPNM            0.250000 │
      │ 39. NAEUCH6QSQIU7MX2UR2UGJY2LJJSITCLXLKTAINX            5.150000 │
      │ 40. NAFDNIFYIO6SKZT52XMXWUAMBTIINCBM7H5OUHWN            0.200000 │
      │ 41. NAFDNCFASSZLM26NNTFNEPGUY2DPZIQYSGGP2MDY            0.650200 │
      │ 42. NBFOUNDXB54PVVPG6AN4WJ7BAOYFBC2XLLHDU5YM            4.150000 │
      │ 43. NBTECH3HN7HL7YO2RRQNTSQ3AQOFYHOZOCA4L7XQ           20.950000 │
      │ 44. NBIZDEVY6NGHCNQBONH7YQUYB6BIKZOGS4OWAD3B            0.500000 │
      │ 45. NBMKTGGGQ2OKGAVIKMFXDFRPDBR4LD563SCVPHWW            0.500000 │
      │ 46. NBREVFFWL2NKFK3QCPMOFH6YLSOMLJGDVFY7ORGH            0.500000 │
      │ 47. NBOPERXIPVSUFFV7X646XKF2PROTNN7QUZF7MFJF            0.500000 │
      │ 48. NBFINANG3FC4WADS2IUMHJRZN5LXIVPFKKS4UCUS            0.500000 │
      │ 49. NBNBCYGQ3ZASNQGXMJXXDNUZ52HSVOTGWIN2F52U           20.000000 │
      └──────────────────────────────────────────────────────────────────┘

       Namespace & Mosaic Sink Addresses
      ┌──────────────────────────────────────────────────────────────────┐                   │
      │ 50. NAMESPACEWH4MKFMBCVFERDPOOP4FK7MTBXDPZZA     11308561.781776 ├───────────────────X Frozen Outflows
      │ 51. NBMOSAICOD4F54EE5CDMR23CCBGOAM2XSIUX6TRS       400664.901143 │                   │
      └──────────────────────────────────────────────────────────────────┘
tags: HardFork, NEM