Skip to content

Latest commit

 

History

History
61 lines (43 loc) · 3.29 KB

nep-29.mediawiki

File metadata and controls

61 lines (43 loc) · 3.29 KB

  NEP: 29
  Title: Contract deployment/update callback function
  Author: Roman Khimov <roman@nspcc.ru>
  Type: Standard
  Status: Accepted
  Created: 2024-07-18

Table of Contents

Abstract

This proposal standardizes the callback function that can be implemented by contracts to have some code executed right after initial deployment or update.

Motivation

Contracts may need to run some initialization/update code right after their deployment or upgrade. Neo N3 has provided a mechanism for that since version 3.0, but it was never properly standardized, so this proposal fixes it.

Specification

Neo N3 has a native ContractManagement contract that is used for contract deployment and update via deploy and update methods of it. After settling with the new NEF and manifest both of them will invoke a special _deploy method if it's implemented by the contract.

Methods

_deploy

{
  "name": "_deploy",
  "safe": false,
  "parameters": [
    {
      "name": "data",
      "type": "Any"
    },
    {
      "name": "update",
      "type": "Boolean"
    }
  ],
  "returntype": "Void"
}

This method will be automatically executed by ContractManagement contract when a contract is first deployed or updated. At this point new contract state is already saved (and it can be called from other code), but Deploy or Update notification is not yet emitted by ContractManagement contract.

The data parameter is completely contract-specific, contracts can accept any valid NEP-14 parameter types and handle them as required. It's the same data that is accepted by deploy and update methods of ContractManagement contract.

update is true when contract is updated via update and it's false on initial deployment via deploy.

Rationale

This callback is designed to guarantee the first code to be executed in a new/updated contract. Previously contracts could provide methods of their own for doing this, but this either required an additional code in deployment/update transaction script or an additional transaction and some special contract state management (to disable actions before some initialization).

_deploy parameters are made to be generic enough to cover all contract state management cases, it is possible to get additional per-network or per-instance contract data for initialization and updates can be easily differentiated from deployments via update parameter.

Notice that if there are any notifications emitted during _deploy execution they will precede Deploy or Update notifications from ContractManagement. This behavior is historic, it mostly means that we're considering contract to be completely ready after succesful _deploy invocation (it can throw an exception or abort execution as well).

Implementation