diff --git a/common/changes/@cityofzion/neon-dappkit-types/CU-86a0uc2km_2023-09-14-20-06.json b/common/changes/@cityofzion/neon-dappkit-types/CU-86a0uc2km_2023-09-14-20-06.json new file mode 100644 index 0000000..3f04b1a --- /dev/null +++ b/common/changes/@cityofzion/neon-dappkit-types/CU-86a0uc2km_2023-09-14-20-06.json @@ -0,0 +1,10 @@ +{ + "changes": [ + { + "packageName": "@cityofzion/neon-dappkit-types", + "comment": "Renamed \"Neo3Involker.ts\" to \"Neo3Invoker.ts\"", + "type": "patch" + } + ], + "packageName": "@cityofzion/neon-dappkit-types" +} \ No newline at end of file diff --git a/common/changes/@cityofzion/neon-dappkit/CU-86a0uc2km_2023-09-14-20-06.json b/common/changes/@cityofzion/neon-dappkit/CU-86a0uc2km_2023-09-14-20-06.json new file mode 100644 index 0000000..7b4a7ad --- /dev/null +++ b/common/changes/@cityofzion/neon-dappkit/CU-86a0uc2km_2023-09-14-20-06.json @@ -0,0 +1,10 @@ +{ + "changes": [ + { + "packageName": "@cityofzion/neon-dappkit", + "comment": "Add \"Struct\" type support on NeonParser", + "type": "patch" + } + ], + "packageName": "@cityofzion/neon-dappkit" +} \ No newline at end of file diff --git a/packages/neon-dappkit-types/dist/Neo3Invoker.d.ts b/packages/neon-dappkit-types/dist/Neo3Invoker.d.ts new file mode 100644 index 0000000..56cf28b --- /dev/null +++ b/packages/neon-dappkit-types/dist/Neo3Invoker.d.ts @@ -0,0 +1,319 @@ +export interface BooleanWitnessCondition { + type: 'Boolean'; + expression: boolean; +} +export interface NotWitnessCondition { + type: 'Not'; + expression: WitnessCondition; +} +export interface AndWitnessCondition { + type: 'And'; + expressions: WitnessCondition[]; +} +export interface OrWitnessCondition { + type: 'Or'; + expressions: WitnessCondition[]; +} +export interface ScriptHashWitnessCondition { + type: 'ScriptHash'; + hash: string; +} +export interface GroupWitnessCondition { + type: 'Group'; + group: string; +} +export interface CalledByEntryWitnessCondition { + type: 'CalledByEntry'; +} +export interface CalledByContractWitnessCondition { + type: 'CalledByContract'; + hash: string; +} +export interface CalledByGroupWitnessCondition { + type: 'CalledByGroup'; + group: string; +} +export type WitnessCondition = BooleanWitnessCondition | AndWitnessCondition | NotWitnessCondition | OrWitnessCondition | ScriptHashWitnessCondition | GroupWitnessCondition | CalledByEntryWitnessCondition | CalledByContractWitnessCondition | CalledByGroupWitnessCondition; +export interface WitnessRule { + action: string; + condition: WitnessCondition; +} +/** + * A simple interface that defines the signing options, which privileges the user needs to give for the SmartContract. + * Usually the default signer is enough: `{ scopes: WitnessScope.CalledByEntry }` + * But you may need additional authorization, for instance, allow the SmartContract to invoke another specific contract: + * + * ``` + * { + * scopes: WitnessScope.CustomContracts, + * allowedContracts: ['0xf970f4ccecd765b63732b821775dc38c25d74f23'] + * } + * ``` + * + */ +export type Signer = { + /** + * The level of permission the invocation needs + */ + scopes: string | number; + /** + * An optional scriptHash to be used to sign, if no account is provided the user selected account will be used + */ + account?: string; + /** + * When the scopes is `WitnessScope.CustomContracts`, you need to specify which contracts are allowed + */ + allowedContracts?: string[]; + /** + * When the scopes is `WitnessScope.CustomGroups`, you need to specify which groups are allowed + */ + allowedGroups?: string[]; + rules?: WitnessRule[]; +}; +export type AnyArgType = { + type: 'Any'; + value: any; +}; +export type StringArgType = { + type: 'String'; + value: string; +}; +export type BooleanArgType = { + type: 'Boolean'; + value: boolean; +}; +export type PublicKeyArgType = { + type: 'PublicKey'; + value: string; +}; +export type Hash160ArgType = { + type: 'Hash160'; + value: string; +}; +export type Hash256ArgType = { + type: 'Hash256'; + value: string; +}; +export type IntegerArgType = { + type: 'Integer'; + value: string; +}; +export type ArrayArgType = { + type: 'Array'; + value: Arg[]; +}; +export type MapArgType = { + type: 'Map'; + value: { + key: Arg; + value: Arg; + }[]; +}; +export type ByteArrayArgType = { + type: 'ByteArray'; + value: string; +}; +export type Arg = AnyArgType | StringArgType | BooleanArgType | PublicKeyArgType | Hash160ArgType | Hash256ArgType | IntegerArgType | ArrayArgType | MapArgType | ByteArrayArgType; +/** + * A simple interface that defines the invocation options + */ +export type ContractInvocation = { + /** + * The SmartContract ScriptHash + */ + scriptHash: string; + /** + * The SmartContract's method name + */ + operation: string; + /** + * The parameters to be sent to the method + */ + args?: Arg[]; + /** + * When requesting multiple invocations, you can set `abortOnFail` to true on some invocations so the VM will abort the rest of the calls if this invocation returns `false` + */ + abortOnFail?: boolean; +}; +/** + * A simple interface that defines the MultiInvoke options + */ +export type ContractInvocationMulti = { + /** + * the signing options + */ + signers?: Signer[]; + /** + * The array of invocations + */ + invocations: ContractInvocation[]; + /** + * an optional fee to be added to the calculated system fee + */ + extraSystemFee?: number; + /** + * for the cases you need to calculate the system fee by yourself + */ + systemFeeOverride?: number; + /** + * an optional fee to be added to the calculated network fee + */ + extraNetworkFee?: number; + /** + * for the cases you need to calculate the network fee by yourself + */ + networkFeeOverride?: number; +}; +export type ArrayResponseArgType = { + type: 'Array'; + value: RpcResponseStackItem[]; +}; +export type MapResponseArgType = { + type: 'Map'; + value: { + key: RpcResponseStackItem; + value: RpcResponseStackItem; + }[]; +}; +export type ByteStringArgType = { + type: 'ByteString'; + value: string; +}; +export type InteropInterfaceArgType = { + type: 'InteropInterface'; + interface: string; + id: string; +}; +export type PointerArgType = { + type: 'Pointer'; + value: string; +}; +export type BufferArgType = { + type: 'Buffer'; + value: string; +}; +export type StructArgType = { + type: 'Struct'; + value: RpcResponseStackItem[]; +}; +export type RpcResponseStackItem = AnyArgType | BooleanArgType | IntegerArgType | ArrayResponseArgType | MapResponseArgType | ByteStringArgType | InteropInterfaceArgType | PointerArgType | BufferArgType | StructArgType; +/** + * Result from calling invokescript or invokefunction. + */ +export interface InvokeResult { + /** The script that is sent for execution on the blockchain as a base64 string. */ + script: string; + /** State of VM on exit. HALT means a successful exit while FAULT means exit with error. */ + state: 'HALT' | 'FAULT'; + /** Amount of gas consumed up to the point of stopping in the VM. If state is FAULT, this value is not representative of the amount of gas it will consume if it somehow succeeds on the blockchain. + * This is a decimal value. + */ + gasconsumed: string; + /** A human-readable string clarifying the exception that occurred. Only available when state is "FAULT". */ + exception: string | null; + stack: T[]; + /** A ready to send transaction that wraps the script. + * Only available when signers are provided and the sender's private key is open in the RPC node. + * Formatted in base64-encoding. + */ + tx?: string; + /** This properties comes when the invoke result is a iterator. You need to call the traverseIterator method to get the real result */ + session?: string; +} +/** + * The entry point for the SmartContract invocation + */ +export interface Neo3Invoker { + /** + * Sends an 'invokeFunction' request to the Wallet and it will communicate with the blockchain. It will consume gas and persist data to the blockchain. + * + * ``` + * const invocations: ContractInvocation[] = [ + * { + * scriptHash: '0x010101c0775af568185025b0ce43cfaa9b990a2a', + * operation: 'getStream', + * abortOnFail: true, // if 'getStream' returns false the next invocation will not be made + * args: [ + * { type: 'Integer', value: 17 } + * ] + * }, + * { + * scriptHash: '0x010101c0775af568185025b0ce43cfaa9b990a2a', + * operation: 'transfer', + * args: [ + * { type: 'Address', value: senderAddress }, + * { type: 'Address', value: 'NbnjKGMBJzJ6j5PHeYhjJDaQ5Vy5UYu4Fv' }, + * { type: 'Integer', value: 100000000 }, + * { type: 'Array', value: [] } + * ] + * } + * ] + * + * const signer: Signer[] = [ + * { + * scopes: WitnessScope.Global + * } + * ] + * + * const formattedRequest: ContractInvocationMulti = { + * signer, + * invocations + * } + * const resp = await invokeFunction(formattedRequest) + * ``` + * + * @param params the contract invocation options + * @return the call result promise. It might only contain the transactionId, another call to the blockchain might be necessary to check the result. + */ + invokeFunction: (cim: ContractInvocationMulti) => Promise; + /** + * Sends a `testInvoke` request to the Wallet and it will communicate with the blockchain. + * It will not consume any gas but it will also not persist any data, this is often used to retrieve SmartContract information or check how much gas an invocation will cost. + * Also, the wallet might choose to not ask the user authorization for test invocations making them easy to use. + * + * ``` + * const signers: Signer[] = [ + * { + * scopes: WitnessScope.None + * } + * ] + * + * const invocations: ContractInvocation[] = [ + * { + * scriptHash: '0x010101c0775af568185025b0ce43cfaa9b990a2a', + * operation: 'getStream', + * abortOnFail: true, // if 'getStream' returns false the next invocation will not be made + * args: [ + * { type: 'Integer', value: 17 } + * ], + * }, + * { + * scriptHash: '0x010101c0775af568185025b0ce43cfaa9b990a2a', + * operation: 'balanceOf', + * args: [ + * { type: 'Address', value: senderAddress } + * ] + * } + * ] + * + * const formattedRequest: ContractInvocationMulti = { + * signers, + * invocations + * } + * const resp = await testInvoke(formattedRequest) + * ``` + * + * @param params the contract invocation options + * @return the call result promise + */ + testInvoke: (cim: ContractInvocationMulti) => Promise; + /** + * Call the method traverseiterator on the rpc. This method is used to get the result of an iterator. + * The result is the first count of data traversed in the Iterator, and follow-up requests will continue traversing from count + 1 + * @param sessionId the session id of the iterator + * @param iteratorId the iterator id + * @param count the number of items to retrieve + * @return the call result promise + */ + traverseIterator: (sessionId: string, iteratorId: string, count: number) => Promise; +} diff --git a/packages/neon-dappkit-types/dist/Neo3Invoker.js b/packages/neon-dappkit-types/dist/Neo3Invoker.js new file mode 100644 index 0000000..c8ad2e5 --- /dev/null +++ b/packages/neon-dappkit-types/dist/Neo3Invoker.js @@ -0,0 +1,2 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); diff --git a/packages/neon-dappkit-types/dist/Neo3Parser.d.ts b/packages/neon-dappkit-types/dist/Neo3Parser.d.ts index 3316d8f..f24da59 100644 --- a/packages/neon-dappkit-types/dist/Neo3Parser.d.ts +++ b/packages/neon-dappkit-types/dist/Neo3Parser.d.ts @@ -1,4 +1,4 @@ -import { Arg, RpcResponseStackItem } from './Neo3Involker'; +import { Arg, RpcResponseStackItem } from './Neo3Invoker'; export interface Neo3Parser { /** * Converts an ArrayBuffer to an ASCII string. diff --git a/packages/neon-dappkit-types/dist/index.d.ts b/packages/neon-dappkit-types/dist/index.d.ts index e6a7607..8f90c7c 100644 --- a/packages/neon-dappkit-types/dist/index.d.ts +++ b/packages/neon-dappkit-types/dist/index.d.ts @@ -1,4 +1,4 @@ export * from './Neo3EventListener'; -export * from './Neo3Involker'; +export * from './Neo3Invoker'; export * from './Neo3Parser'; export * from './Neo3Signer'; diff --git a/packages/neon-dappkit-types/dist/index.js b/packages/neon-dappkit-types/dist/index.js index 7e1e642..41720f6 100644 --- a/packages/neon-dappkit-types/dist/index.js +++ b/packages/neon-dappkit-types/dist/index.js @@ -15,6 +15,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) { }; Object.defineProperty(exports, "__esModule", { value: true }); __exportStar(require("./Neo3EventListener"), exports); -__exportStar(require("./Neo3Involker"), exports); +__exportStar(require("./Neo3Invoker"), exports); __exportStar(require("./Neo3Parser"), exports); __exportStar(require("./Neo3Signer"), exports); diff --git a/packages/neon-dappkit-types/docs/enums/SignMessageVersion.html b/packages/neon-dappkit-types/docs/enums/SignMessageVersion.html index 294e65d..58154a5 100644 --- a/packages/neon-dappkit-types/docs/enums/SignMessageVersion.html +++ b/packages/neon-dappkit-types/docs/enums/SignMessageVersion.html @@ -19,7 +19,7 @@

Enumeration SignMessageVersion

A version enum that indicates how a message should be signed

+
  • Defined in Neo3Signer.ts:4
  • @@ -37,17 +37,17 @@

    Enumeration Members

    CLASSIC: 1
    +
  • Defined in Neo3Signer.ts:5
  • DEFAULT: 2
    +
  • Defined in Neo3Signer.ts:6
  • WITHOUT_SALT: 3
    +
  • Defined in Neo3Signer.ts:7
  • +
  • Defined in Neo3Invoker.ts:205
  • script: string

    The script that is sent for execution on the blockchain as a base64 string.

    +
  • Defined in Neo3Invoker.ts:199
  • session?: string

    This properties comes when the invoke result is a iterator. You need to call the traverseIterator method to get the real result

    +
  • Defined in Neo3Invoker.ts:215
  • stack: T[]
    +
  • Defined in Neo3Invoker.ts:208
  • state: "HALT" | "FAULT"

    State of VM on exit. HALT means a successful exit while FAULT means exit with error.

    +
  • Defined in Neo3Invoker.ts:201
  • tx?: string
    @@ -95,7 +95,7 @@
    +
  • Defined in Neo3Invoker.ts:213
  • Returns void

    +
  • Defined in Neo3EventListener.ts:76
  • Returns void

    +
  • Defined in Neo3EventListener.ts:61
    • @@ -118,7 +118,7 @@
      txId: string

    Returns Promise<Neo3ApplicationLog>

    +
  • Defined in Neo3EventListener.ts:67
  • +
  • Defined in Neo3EventListener.ts:13
  • +
  • Defined in Neo3Invoker.ts:263
  • @@ -86,7 +86,7 @@

    Parameters

    cim: ContractInvocationMulti

    Returns Promise<InvokeResult<RpcResponseStackItem>>

    +
  • Defined in Neo3Invoker.ts:305
  • traverseIterator: ((sessionId: string, iteratorId: string, count: number) => Promise<RpcResponseStackItem[]>)
    @@ -119,7 +119,7 @@
    count: number

    Returns Promise<RpcResponseStackItem[]>

    +
  • Defined in Neo3Invoker.ts:315
  • +
  • Defined in Neo3Parser.ts:23
  • abToStr: ((buf: ArrayBuffer | ArrayLike<number>) => string)
    @@ -90,7 +90,7 @@

    Parameters

    buf: ArrayBuffer | ArrayLike<number>

    Returns string

    +
  • Defined in Neo3Parser.ts:8
  • accountInputToAddress: ((input: string) => string)
    @@ -110,7 +110,7 @@

    Parameters

    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:90
  • accountInputToScripthash: ((input: string) => string)
    @@ -130,7 +130,7 @@

    Parameters

    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:80
  • asciiToBase64: ((input: string) => string)
    @@ -150,7 +150,7 @@

    Parameters

    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:70
  • base64ToHex: ((input: string) => string)
    @@ -170,7 +170,7 @@

    Parameters

    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:60
  • base64ToUtf8: ((input: string) => string)
    @@ -190,7 +190,7 @@

    Parameters

    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:75
  • formatRpcArgument: ((arg: any, parseConfig?: ParseConfig) => Arg)
    @@ -216,7 +216,7 @@
    Optional parseConfig: Returns Arg
    +
  • Defined in Neo3Parser.ts:106
  • hexToBase64: ((input: string) => string)
    @@ -236,7 +236,7 @@

    Parameters

    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:55
  • hexstringToAb: ((str: string) => Uint8Array)
    @@ -256,7 +256,7 @@

    Parameters

    str: string

    Returns Uint8Array

    +
  • Defined in Neo3Parser.ts:18
  • hexstringToStr: ((hexstring: string) => string)
    @@ -276,7 +276,7 @@

    Parameters

    hexstring: string

    Returns string

    +
  • Defined in Neo3Parser.ts:33
  • intToHex: ((num: number) => string)
    @@ -296,7 +296,7 @@

    Parameters

    num: number

    Returns string

    +
  • Defined in Neo3Parser.ts:38
  • numToHexstring: ((num: number, size?: number, littleEndian?: boolean) => string)
    @@ -326,7 +326,7 @@
    Optional littleEndian:

    Returns string

    +
  • Defined in Neo3Parser.ts:45
  • numToVarInt: ((num: number) => string)
    @@ -346,7 +346,7 @@

    Parameters

    num: number

    Returns string

    +
  • Defined in Neo3Parser.ts:50
  • parseRpcResponse: ((field: RpcResponseStackItem, parseConfig?: ParseConfig) => any)
    @@ -368,7 +368,7 @@
    field: Optional parseConfig: ParseConfig

    Returns any

    +
  • Defined in Neo3Parser.ts:100
  • reverseHex: ((input: string) => string)
    @@ -388,7 +388,7 @@

    Parameters

    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:95
  • strToAb: ((str: string) => Uint8Array)
    @@ -408,7 +408,7 @@

    Parameters

    str: string

    Returns Uint8Array

    +
  • Defined in Neo3Parser.ts:13
  • strToBase64: ((input: string) => string)
    @@ -430,7 +430,7 @@
    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:85
  • strToHexstring: ((str: string) => string)
    @@ -450,7 +450,7 @@

    Parameters

    str: string

    Returns string

    +
  • Defined in Neo3Parser.ts:28
  • utf8ToBase64: ((input: string) => string)
    @@ -470,7 +470,7 @@

    Parameters

    input: string

    Returns string

    +
  • Defined in Neo3Parser.ts:65
  • Returns Promise<DecryptFromArrayResult>

    +
  • Defined in Neo3Signer.ts:99
  • +
  • Defined in Neo3Signer.ts:84
  • +
  • Defined in Neo3Signer.ts:76
  • +
  • Defined in Neo3Signer.ts:64
    • @@ -150,7 +150,7 @@
      params:

    Returns Promise<boolean>

    +
  • Defined in Neo3Signer.ts:71
  • +
  • Defined in Neo3Invoker.ts:99
  • +
  • Defined in Neo3Parser.ts:109
  • +
  • Defined in Neo3Invoker.ts:110
  • +
  • Defined in Neo3Invoker.ts:106
  • +
  • Defined in Neo3Parser.ts:117
  • +
  • Defined in Neo3Invoker.ts:174
  • +
  • Defined in Neo3Invoker.ts:101
  • +
  • Defined in Neo3Parser.ts:111
  • +
  • Defined in Neo3Invoker.ts:179
  • +
  • Defined in Neo3Invoker.ts:108
  • +
  • Defined in Neo3Parser.ts:112
  • +
  • Defined in Neo3Invoker.ts:176
  • +
  • Defined in Neo3Invoker.ts:125
  • +
  • Defined in Neo3Invoker.ts:147
  • +
  • Defined in Neo3Invoker.ts:103
  • +
  • Defined in Neo3Parser.ts:114
  • +
  • Defined in Neo3Invoker.ts:104
  • +
  • Defined in Neo3Parser.ts:115
  • +
  • Defined in Neo3Invoker.ts:105
  • +
  • Defined in Neo3Parser.ts:116
  • +
  • Defined in Neo3Invoker.ts:177
  • +
  • Defined in Neo3Parser.ts:119
  • +
  • Defined in Neo3Invoker.ts:107
  • +
  • Defined in Neo3Parser.ts:118
  • +
  • Defined in Neo3Invoker.ts:175
  • +
  • Defined in Neo3EventListener.ts:19
  • +
  • Defined in Neo3Parser.ts:121
  • +
  • Defined in Neo3Invoker.ts:178
  • +
  • Defined in Neo3Invoker.ts:102
  • +
  • Defined in Neo3Parser.ts:113
  • +
  • Defined in Neo3Invoker.ts:182
  • +
  • Defined in Neo3Signer.ts:13
  • +
  • Defined in Neo3Signer.ts:21
  • +
  • Defined in Neo3Invoker.ts:78
  • +
  • Defined in Neo3Invoker.ts:100
  • +
  • Defined in Neo3Parser.ts:110
  • +
  • Defined in Neo3Invoker.ts:180
  • +
  • Defined in Neo3Invoker.ts:49
  • +
  • Defined in Neo3Parser.ts:147
  • +
  • Defined in Neo3Parser.ts:163
  • +
  • Defined in Neo3Parser.ts:134