Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove sender from invoke method #368

Merged
merged 6 commits into from
Oct 19, 2020

Conversation

Tommo-L
Copy link
Contributor

@Tommo-L Tommo-L commented Oct 9, 2020

Fix #351

Copy link
Contributor

@devhawk devhawk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we get our story straight on the sender parameter? @cloud8little just asked me to add the parameter to the new async RpcCLient PR: #335 (comment)

@Tommo-L Tommo-L mentioned this pull request Oct 10, 2020
@Tommo-L
Copy link
Contributor Author

Tommo-L commented Oct 10, 2020

Can we get our story straight on the sender parameter? @cloud8little just asked me to add the parameter to the new async RpcCLient PR: #335 (comment)

Signers[0] is the sender.

@cloud8little
Copy link
Contributor

why we make this change #309 before?

@cloud8little
Copy link
Contributor

Can we get our story straight on the sender parameter? @cloud8little just asked me to add the parameter to the new async RpcCLient PR: #335 (comment)

@devhawk I got it clear from #368 (review), no need to add sender.

@superboyiii
Copy link
Member

superboyiii commented Oct 10, 2020

Can we get our story straight on the sender parameter? @cloud8little just asked me to add the parameter to the new async RpcCLient PR: #335 (comment)

Signers[0] is the sender.

Why Signers[0] should be the sender? Signers[1], Signers[2] could also be sender, that's why we have to confirm the sender in params.
For invokefunction, you could see neo-cli is like this: https://github.com/neo-project/neo-node/blob/184db447499e82f4aae57ae686800f9a434618a3/neo-cli/CLI/MainService.Contracts.cs#L55

@superboyiii
Copy link
Member

superboyiii commented Oct 10, 2020

Due to my test for this PR:

  1. if sender is Signers[0] and Signers[0] doesn't have any GAS, then it will choose Signers[1] as sender (if Signers[1] has enough GAS) when MakeTransaction.
  2. if Signers[0] and Signers[1] both have enough GAS, sender will be Signers[0] even if I set Signers[1] as Signer in Json Request.

I think this change would make sender more confusion because we want Signers[0] to be sender, but in fact it still can't always be like this. Then why we have to set Signers[0] to be sender? Developers have their authority to choose which is the sender.

@roman-khimov

@roman-khimov
Copy link
Contributor

Developers have their authority to choose which is the sender.

Absolutely if you're to transfer signers given to "invoke*" into transaction 1:1. They'd get exactly the sender/signers they want this way.

@superboyiii
Copy link
Member

Developers have their authority to choose which is the sender.

Absolutely if you're to transfer signers given to "invoke*" into transaction 1:1. They'd get exactly the sender/signers they want this way.

Now I agree with you, just wait for solving #370

@superboyiii
Copy link
Member

superboyiii commented Oct 13, 2020

Let's make a summary:

  1. sender should be from the input signer[].
  2. If the input signer[0] hasn't enough GAS for making Tx, it could use signer[1], signer[2]... to be sender if it exists in the input signer[] and it has enough GAS as well. Or an error msg should be returned such as "Insufficient GAS".
  3. Signer[] and sender should be from the input params but not from wallet class, should never automatically choose an address from wallet to be sender or signer[] even if the input Signer[] doesn't have enough GAS, the response should always be from what we input.
  4. Non-asset address should not be in the signer[] list unless one of the signers in signer[] has enough GAS, and the scopes type of signer is also strange(should not be None).
    image

@roman-khimov
Copy link
Contributor

Just leave the first point and that's it. Second one is not necessary, it's up to the user of this API to order signers correctly, so if signer[0] doesn't have enough GAS --- it's not a problem of RPC server. Think also of RPC servers that don't manage wallets like C# one does, they just do 1:1 mapping from invoke* signers into transaction signers and don't care about balances at all, it's not their problem.

@superboyiii
Copy link
Member

Just leave the first point and that's it. Second one is not necessary, it's up to the user of this API to order signers correctly, so if signer[0] doesn't have enough GAS --- it's not a problem of RPC server. Think also of RPC servers that don't manage wallets like C# one does, they just do 1:1 mapping from invoke* signers into transaction signers and don't care about balances at all, it's not their problem.

But current neo-cli is designed to care, we should solve this conflict in wallet.cs. Current MakeTransaction will check balance when invoking invokefunction, I think a new MakeTransaction should be created for this.

@superboyiii
Copy link
Member

superboyiii commented Oct 19, 2020

Merged with latest, find it work well when signers[0] doesn't have enough gas.

{
  "jsonrpc": "2.0",
  "method": "invokefunction",
  "params": [
    "0x254b9decd76080ef368e7a6b0a065938dfbc31cf",
    "balanceOf",
    [
      {
        "type": "Hash160",
        "value": "0xf642a0401fdd56a03114639a98b7963eb587a30a"
      }
    ],
    [
      {
        "account": "0x7170793e96092211675c8333395d79c465a4f56f",
        "scopes": "CalledByEntry"
      },
      {
        "account": "0xf642a0401fdd56a03114639a98b7963eb587a30a",
        "scopes": "CalledByEntry"
      }
    ]
  ],
  "id": 3
}
{
    "jsonrpc": "2.0",
    "id": 3,
    "result": {
        "script": "DBQKo4e1Ppa3mJpjFDGgVt0fQKBC9hHADAliYWxhbmNlT2YMFM8xvN84WQYKa3qONu+AYNfsnUslQWJ9W1I=",
        "state": "HALT",
        "gasconsumed": "3840690",
        "exception": "Insufficient GAS",
        "stack": [
            {
                "type": "Integer",
                "value": "2000000000000000"
            }
        ]
    }
}

Any more change requested? @devhawk

@superboyiii superboyiii requested a review from devhawk October 19, 2020 07:14
Copy link
Contributor

@devhawk devhawk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍

UInt160 sender = _params.Count >= 2 ? AddressToScriptHash(_params[1].AsString()) : null;
Signers signers = _params.Count >= 3 ? SignersFromJson((JArray)_params[2]) : null;
return GetInvokeResult(script, sender, signers);
byte[] script = _params[0].AsString().HexToBytes();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The modification of #362 goes back here 🤔

ProDog added a commit to ProDog/neo-modules that referenced this pull request Nov 5, 2020
@ProDog ProDog mentioned this pull request Nov 5, 2020
shargon pushed a commit that referenced this pull request Nov 5, 2020
chenzhitong pushed a commit to chenzhitong/neo-modules that referenced this pull request Nov 25, 2020
* add SimplePolicy

* add ApplicationLogs

* use leveldb in ApplicationLogs

* update dependency: Neo v3.0.0-preview2-04

Close #1

* Logging in millisecs

After change to Akka consensus in NEO 3.0, it's so fast that seconds do not mean much anymore.. now milliseconds is important to actually know of what is going on the consensus algorithm.

* remove break statement from FilterFree

* Fix Priority Fee Transactions being treated as Free (#4)

* add RpcDisabled

* add StatesDumper

* add ImportBlocks (#7)

* `yield break` when the height of the imported block reaches the limit

* detect recursive references in ApplicationLogs

* exporting blocks in plugin

* copy config.json to output directory automatically

* v2.9.0 (#9)

* fix SimplePolicyPlugin

* fix neo-project/neo#395

* Rpc Basic Auth (#14)

* Rpc Basic Auth

* change plugin name to RpcSecurity

* Including number of dumped states (#17)

* Including number of dumped states

* Update StatesDumper/StatesDumper.cs

Co-Authored-By: vncoelho <[email protected]>

* Readme (#18)

* misspelling (#26)

* Help for Plugins (#28)

* Transaction size plugin (#10)

* Update packages reference (#22)

* Basic unit test structure for SimplePolicyPlugin (#25)

* Persitence Plugin for exporting storage changes (#21)

* Persitence Plugin first draft

* Fixing some compiling problems. Trackable is still not found in the local scope.

* Minnor changes. Trackable still not found

* Fixing all compiling errors and Trackable

* Fixing StorageKey and Item get values

* Switch case Persist Action and fixing Storage export

* Adding Height To Being

* Moving plugin to StatesDumper

* minnor comments

* remove StatesDumper.sln

* format

* remove `Settings.BlockStorageCache`

* add `PersistActions`

* v2.9.3 (#31)

* Update packages reference

* Fix claim (#34)

* v2.9.4

* Expose the max TX per block and max low priority TX per block. (neo-project#37)

* Ensure PoW correct order for TXs tiebreakers (neo-project#38)

* Ensure PoW correct order for TXs tiebreakers

* ThenByAscending for Hash

* Expose HighPriorityTxType (neo-project#39)

* Expose HighPriorityTxType

* HigherLowPriorityTxTypes

* InHigherLowPriorityList

* Modify missing InHigherLowPriorityList

* Missing InHigherLowPriorityList

* Use InHigherLowPriorityList and change to public

* Clean

* Clean II

* Commit as the final step of persistence in StatesDumper (neo-project#40)

* Support commit as the final step of persistence.

* Update for new method .

* OnCommitStorage

* Adding tests and fixing typo (neo-project#41)

* Adding tests and fixing typo

* adding random attribute to claim

* unit tests for hash compare

* Creating Travis CI for neo-plugins (neo-project#42)

* Including PreProcess and PostProcess functions (neo-project#46)

* Including PreProcess and PostProcess functions

* Adding pre-post to RpcSecurity

* Fix missing public declaration (neo-project#48)

* Add RpcWallet (neo-project#44)

* Add RpcWallet

* Add `importprivkey`

* Add `from` parameter to `sendmany`

* Add `getunclaimedgas`

* Add `claimgas`

* Add reference: Neo 2.10.0

* Fix `importprivkey`

* Add plugin for NEP5 balances and transfer history (Persistence + RPC) (neo-project#43)

* Check authentication during pre-processing. (neo-project#54)

* v2.10.0

* Fix memory leak of LevelDB snapshots. (neo-project#57)

* Use IPersistencePlugin and batch Application Log writes. (neo-project#62)

* Fix sizes for RpcNep5Tracker (neo-project#67)

* Plugin CoreMetrics (neo-project#68)

* Plugin coreMetrics.

* Organize project files

* metric prefix

* Make calculation for extra gas on "send*" RPC (neo-project#70)

* Make calculation for extra gas on "send*" RPC

* Fix for the calculation when little overstep

* Add Max_Fee as the optional for gas limit. (neo-project#74)

* Make calculation for extra gas on "send*" RPC (neo-project#70)

* Make calculation for extra gas on "send*" RPC

* Fix for the calculation when little overstep

* Delete the dependency which is for testing purpose

* Choose the max_fee between  fee and extra_fee

* Change error codes

* Update Settings.cs

* format

* Add `NuGet.Config`

* fix size calculation (neo-project#75)

* Add Plugin for UTXO tracking by account. (neo-project#65)

* Add Plugin for UTXO tracking by account.

* Rename RpcSystemAssetPlugin -> RpcSystemAssetTracker.

* Accept address or script hash.

* Remove unnecessary white space.

* Update project ref to Neo 2.10.1-CI00002.

* Ensure consistency in case of crash or kill.

* Fix setting lastPersistedBlock after each block is persisted.

* Performance optimization: Don't write block number for empty blocks.

* Optimize.

* Add support for tracking unclaimed spent outputs.

* Provide getclaimable RPC call for getting available claim spent outputs.

* Clean-up.

* Don't leak memory.

* Implement getclaimable to get get total unclaimed amount for an address.

* Remove unnecessary comment.

* Fix size of UserSystemAssetCoinOutputs. Remove unused using statement.

* Reload max utxo's from configuration if it changes.

* Upgrade dependency

* Fix .sln for neo-project#65

* Updating Readme information (neo-project#76)

* Fixes `ImportBlocks` for Neo 2.10.1 (neo-project#78)

* v2.10.1

* Properly stop importing blocks on system shutdown. (neo-project#66)

* RpcNep5Tracker: Handle NEP5 transfers to/from null & limit max results (neo-project#71)

* Handle NEP5 transfers to/from null.
* Add support for tracking tokens using non-standard mintToken event.
* Implement maximum results to return for transfer history.
* Make whether to support tracking null address history configurable. Default to false.
* Better input validation
* Support tracking non-standard mintTokens event, but default to off.

* Small optimization (neo-project#82)

* Updating travis (neo-project#84)

* Fix output json for multisigaddress transaction (neo-project#86)

* Fix output json for multisigaddress transaction 

Fix output json for multisigaddress transaction

* format

* format

* Fix the height to end with (neo-project#88)

* Fix-heightToEnd

* Minor fix and comment

* Minor fix on storage state dumper parameter HeightToStartRealTimeSyncing (neo-project#91)

* Minor fix on storage state dumper parameter HeightToStartRealTimeSyncing

* Update StatesDumper/StatesDumper.cs

Co-Authored-By: vncoelho <[email protected]>

* Prevent exceed the height (neo-project#92)

* Update CoreMetrics.cs

I think that it could be exceeded the max height using the `lastHeight` parameter

* Update CoreMetrics.cs

* v2.10.2 (neo-project#96)

* Update CoreMetrics.cs (neo-project#94)

* Update dependency: Neo v3.0.0-CI00044 (neo-project#98)

* Updating README - Removing Asset Tracker plugin (neo-project#104)

Removing description of asset tracker plugin from NEO 3.0 plugins readme

* Prevent DoS with wrong files (neo-project#81)

* Prevent DoS with wrong files

* Constant

* Throw exception

* Clean

* Fixing uint to ulong for some plugins due to seconds to ms change (neo-project#107)

* Fixing uint to ulong for some plugins

* Removing .sln files

* Updating nuget to more recent daily build

* Removing SimplePolicy plugin (neo-project#110)

* Clean SimplePolicy

* Removing travis

* Completely removing SimplePolicy

* Updating readme

* Re-adding travis

* Dotnet restore on Travis

* Cleaning .sln

* Cleaning SP-UT

* SystemLog plugin (neo-project#117)

* CI00151 (neo-project#111)

* Remove `mintTokens` from RpcNep5Tracker

* Fixes deadlock in RpcNep5Tracker (neo-project#128)

* Updating README with RPC Wallet and SystemLog (neo-project#126)

* Fix RpcNep5Tracker (neo-project#125)

* Fixes output of `getbalance` (neo-project#132)

* Fix/memory (neo-project#135)

* use Singleton.Store.GetBlock optimize memory cause

* refactor

* v3.0.0-preview1 (neo-project#136)

* Update to v3.0.0-preview1

* update version number

* Fix cell on maxNBlocksPerDay (3.X) (neo-project#142)

* Fix cell on maxNBlocksPerDay

uint (86400/15000*10000) equals 5000 but not 5760 because ```maxNBlocksPerDay``` is uint but not float.

* Delete incoverable code

Delete incoverable code since unint can't be <0,. For example: uint(-1) = uint 4294967295.

* Fix nBlocks == 0

Fix nBlocks == 0

* Upgrade dependencies and target frameworks (neo-project#147)

* Upgrade dependencies and target frameworks

* Update .travis.yml

* IStorage (neo-project#148)

* Fix UT (neo-project#149)

* Update RpcNep5Tracker/RpcNep5Tracker.cs

Co-Authored-By: Erik Zhang <[email protected]>

* Update RpcNep5Tracker/RpcNep5Tracker.cs

Co-Authored-By: Erik Zhang <[email protected]>

* Update RpcNep5Tracker/RpcNep5Tracker.cs

Co-Authored-By: Erik Zhang <[email protected]>

* Remove Travis and use Github Actions (neo-project#151)

* Fix SystemLog

* Add LevelDBStore (neo-project#150)

* Neo v3.0.0-CI00817

* Fix leveldb (neo-project#153)

* Fix ApplicationLog (neo-project#154)

* Dispose ApplicationEngine after using (neo-project#156)

* RocksDb storage plugin (neo-project#144)

* RocksDb plugin

* Update IStoragePlugin.cs

* Clean name

* Refactor as IStore

* Remove Helper

* Reorder

* Remove IStorage

* Reduce sln changes

* sln bom

* Clean and optimize

* Update nuget

* Create and cache only families if are used

* Rename namespaces

* Rename classes

* 3.0 version

* Format

* Rename the directory

* SetSync

* Remove the DbOptions wrapper

* Update Options.cs

* Remove RocksDBCore

* Remove ColumnFamily.cs

* Rename RocksDbSnapshot to Snapshot

* Add config.json

* Update RocksDBStore.csproj

* Add storage UT

* Fix RocksDb

* Update dotnetcore.yml

* Update dotnetcore.yml

* Copy fix leveldb

* Remove test

* Remove comment

* Fix the fix

* Fix Clear method

* Some changes

* Fix sln

* Update dotnetcore.yml

* sudo apt

* add leveldb

* Update dotnetcore.yml

* Fix Dispose and add UT

* Clean using

* Optimize LevelDB init

* Move projects to src (neo-project#159)

* Remove ImportBlocks (neo-project#161)

* Update .sln

* Rename tests

* Add RpcClient (neo-project#163)

* Remove CoreMetrics (neo-project#164)

* Coveralls (neo-project#165)

* Add RpcServer (neo-project#160)

* Update README.md (neo-project#146)

* Update NuGet versions of all modules (neo-project#174)

* Update-package-rpc-client

* Update nuget

* Update Crypto.ECDsaVerify

* Update TransactionManager.cs

* Some fixes

* Change from public to protected as in level db (neo-project#177)

* Change from public to protected as in level db

* Update RocksDBStore.csproj

Co-authored-by: Shargon <[email protected]>

* Update neo nuget

* change network fee calculation (neo-project#178)

* change network fee calculation

* update to CI00847

* fix fee issue

* add UT for network fee

* Update versions

* Update src/RpcClient/TransactionManager.cs

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Krain Chen <[email protected]>

* Rpc limits (3x) (neo-project#172)

* Add some limits to rpc

* Updating to peer and comments

* Allow to configure MaxConcurrentConnections

* Enter

Co-authored-by: Vitor Nazário Coelho <[email protected]>

* update readme (neo-project#169)

* update readme

* more details for rpc-related plugins

* desc for plugin dependency

* add logo

* Improvement

Improvement

* Delete --log

Delete --log

* Format

Format

* Minor changes

* Adding note about NEP5 functionalities

* Updating with RpcServer

* Fix

Fix

* Format

Format

* Remove StorageEngine

Remove StorageEngine

Co-authored-by: Owen Zhang <[email protected]>
Co-authored-by: Vitor Nazário Coelho <[email protected]>
Co-authored-by: Shargon <[email protected]>

* dotnet-format (neo-project#185)

* Fix

* Fix

* Add dotnet format version

* Fix version

* Update main.yml

* Update main.yml

* Update main.yml

* Fix RpcServer[GetStorage] (neo-project#183)

* Fix RpcServer.Blockchain.cs[GetStorage], using id to be key.

* Accept id and hash

Co-authored-by: Shargon <[email protected]>

* Update Neo nuget to 3.0.0-CI00855 (neo-project#186)

* Update Neo nuget to 3.0.0-CI00855

* update

update

* fix balance not change for non-transfer tx (neo-project#181)

* fix balance not change for non-transfer tx

* deal with gas burn seperately

* remove conversion to null

* check stackitem null

* Fix IsNull

* Remove nullable

* Use constant

* PR correction

* modify check statement

* bug ifix

* send stackitem.null

* not tracker non-tx transfer history

* format

* format

* add check for invalid address

Co-authored-by: Shargon <[email protected]>

* adapt RpcClient to modules (neo-project#171)

* adapt RpcClient to modules

* fix json issue

* fix size calculate

* Fix getnep5balances name issue

* add wallet rpc methods, reconstruct rpc UT

* PR correction

* move models to rpc server

* delete models from rpcclient

* change plugins with model

* format names

* move models back to rpc client

* fix build error

* change test file

* auto calculate network fee, update version

* format code

* fix issue #1416 Deal with ContractParameterType.Any

* change GetStorage parameter to enable id query

* add test for issue #1416

* PR correction

* use snake_case in json

* update neo version

* Update src/RpcClient/RpcClient.cs

Co-Authored-By: Shargon <[email protected]>

* Update src/RpcClient/RpcClient.cs

Co-Authored-By: Shargon <[email protected]>

* PR correction

* update neo version

Co-authored-by: Vitor Nazário Coelho <[email protected]>
Co-authored-by: Nicole <[email protected]>
Co-authored-by: Shargon <[email protected]>

* Deal with contract destory (neo-project#196)

* deal with contract destory

* remove delete key

* Remove GetBlockSysFee (neo-project#199)

* remove GetSysFeeAmount in rpcserver

* remove getblocksysfee in rpcclient

* fix ut

Co-authored-by: Vitor Nazário Coelho <[email protected]>

* ByteArray -> ByteString (neo-project#215)

* Change module command (neo-project#187)

* change command

* Change comment

* Add nuget

* Update StatesDumper.cs

* Fix RelayResult issue (neo-project#220)

* Add CheckWitness to func invokefunction (neo-project#214)

* remove round up sysfee (neo-project#219)

Co-authored-by: Vitor Nazário Coelho <[email protected]>

* Enable programmatic configuration of RpcServer plugin (neo-project#206)

* seperate out plugin from rpcServer functionality

* Update src/RpcServer/RpcServer.cs

* CR Feedback

* fix encoding

* fix build break

Co-authored-by: Harry Pierson <[email protected]>
Co-authored-by: Shargon <[email protected]>

* Fix SystemLog (neo-project#222)

* Update and consolidate nugets (neo-project#194)

* add multi-sig-transfer (neo-project#213)

* Update nugets (neo-project#226)

* Add StackItem ToJson (neo-project#221)

* Override RpcServerPlugin's name (neo-project#235)

* Fix RpcServer RegisterMethods (neo-project#239)

* Fix RpcServer RegisterMethods

* Update RpcServerPlugin.cs

OnPluginsLoaded() will do RegisterMethods

* Update nugets (neo-project#233)

* Close 232

* Sync to the latest neo.

* Fix UT

* Deal with exceptions

* Use last version

* Fix compilation

* Fix RPC module UTs.

Co-authored-by: superboyiii <[email protected]>
Co-authored-by: zhuoqian <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* Allow to share logs in read mode (neo-project#240)

* Allow to share logs in read mode

* Catch exception

* Update Logger.cs

* format

format

Co-authored-by: Owen Zhang <[email protected]>

* Create generic getunclaimedgas and rename wallet ones (neo-project#243)

* Create generic getunclaimedgas and rename wallet ones

* Throw exception

* fix relay tx (neo-project#249)

* add issue template (neo-project#250)

* delete systemlog plugin (neo-project#246)

Co-authored-by: Shargon <[email protected]>

* Add plugin desc and fix ut (neo-project#257)

* add plugin desc and sync neo-core

* format

Co-authored-by: Vitor Nazário Coelho <[email protected]>

* Convert StackItem directly to json (neo-project#264)

* Change json field names for GetVersion (neo-project#262)

Co-authored-by: Shargon <[email protected]>

* remove system log (neo-project#272)

* Neo.VM.3.0.0-CI00958 (neo-project#274)

* fix

* fix event

* CI00958

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Erik Zhang <[email protected]>

* Add EventName to NotifyEventArgs (neo-project#267)

* Add EventName to NotifyEventArgs

* Update UT cases

* Change to all lower case

* Fix UTs

* Fix format

* Fix format again

* Replace db.Find by db.Seek (neo-project#279)

* replace find by seek

* add db.seek

* fix

* format

Co-authored-by: Luchuan <[email protected]>

* Add a generic GetUnclaimedGas() in RpcClient (neo-project#273)

* Add GetUnclaimedGas() in RpcClient and UT

* Fix format

* Update tests/Neo.Network.RPC.Tests/RpcTestCases.json

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Shargon <[email protected]>

* Fix seek (neo-project#281)

* fix seek

* move Helper method

* Update Helper.cs

Co-authored-by: Luchuan <[email protected]>

* Change json fields to all lower case for consistency (neo-project#277)

* Change json field names for GetVersion

* Change json fields to snake case for consistency

* Change json fields to all lower case

* Fix UTs.

* rename

* Add back GetUnclaimedGas()

* Remove "_" in RpcNep5Tracker.cs

* Remove underscore line

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Luchuan <[email protected]>

* fix add signature in invokefunction and invokescript (neo-project#280)

* fix add signature in invokefunction and invokescript

* Update RpcServer.SmartContract.cs

* rename

* fix format

* add exception if wallet or cosigners is null

* Set the default tx to null

Co-authored-by: Shargon <[email protected]>

* update nuget (neo-project#283)

* update nuget

* remove GasFree

* resolve conflict

Co-authored-by: Owen Zhang <[email protected]>

* update IStorageProvider (neo-project#285)

* update signers for invokefunction and invokescript (neo-project#286)

* update signers for invokefunction and invokescript

* fix format

* Validate signer format

Co-authored-by: Shargon <[email protected]>

* Add BloomFilter to levelDB (neo-project#253)

* Add BloomFilter to levelDB

* Code optimization

* Code optimization

* Optimize bloomfilter bits per key value

* Hard-code bloomfilter bitsPeyKey to 15

* Code optimization

Co-authored-by: Jin Qiao <[email protected]>
Co-authored-by: Shargon <[email protected]>
Co-authored-by: Erik Zhang <[email protected]>

* Solve workflow conflict (neo-project#294)

* Solve workflow conflict

Solve workflow conflict from master-2.x and master

* Update main.yml

Apply neo-project/neo#1775

Co-authored-by: Shargon <[email protected]>

* update InvokeFunction (neo-project#295)

* Fix db.Seek (neo-project#291)

* add db.seek ut

* fix db.seek

* remove ByteArrayCompare

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Shargon <[email protected]>

* update RpcClient (neo-project#296)

* update RpcClient

* fix sln

* fix format

* fix format

Co-authored-by: Owen Zhang <[email protected]>

* Add Utility.StackItemFromJson (neo-project#302)

* fix invoke tojson

* add StackItemFromJson

* optimize code

* remove src/RpcClientTests/UtilityTests.cs

Co-authored-by: Luchuan <[email protected]>

* Merge Preview3 to Master (neo-project#307)

* Add Utility.StackItemFromJson (neo-project#302) (neo-project#303)

* fix invoke tojson

* add StackItemFromJson

* optimize code

* remove src/RpcClientTests/UtilityTests.cs

Co-authored-by: Luchuan <[email protected]>

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Luchuan <[email protected]>

* update to preview3 (neo-project#305)

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Luchuan <[email protected]>

* fix neo-project#312 (neo-project#319)

* Allow to try to repair leveldb before opening (neo-project#322)

* update applicationLogs serialization (neo-project#321)

* Remove old bug (neo-project#331)

* Optimize RocksDb startup (neo-project#333)

* Fix RocksDb (neo-project#332)

* Add Getcommittee (neo-project#342)

* update signers and add sender for rpc api (neo-project#309)

* Optimize the result of 'getnep5transfers' (neo-project#345)

* Update RpcNep5Tracker.cs

* Update RpcNep5Tracker.cs

Co-authored-by: Erik Zhang <[email protected]>

* Allow querying contracts by name (neo-project#340)

* Update dependencies (neo-project#338)

* Neo 3.0.0-CI01036 (neo-project#353)

* upgrade neo-core

* Add statesdumper

Co-authored-by: Shargon <[email protected]>

* Replace getvalidators by getnextblockvalidators (neo-project#366)

* Pure async RpcClient (neo-project#335)

* compiling, some stuff stubbed out

* more tests working

* MakeTxContext

* mistake in GetBlock/GetBlockHeader

* rework TransactionManager to be closer to original

* more unit tests (2 still failing)

* remove assertEx

* Add ThrowsAsync comment

* ReturnsAsync

* fixed last remaining test issues

* minor TXManager cleanup

* formatting

* move tx contruction to MakeTransaction

* discards

* Async Suffixes (PR feedback)

* GetCommitteeAsync

* add custom magic support to tx manager

* fix format

* add magic param comment

* CR Feedback

* Clean enter

Co-authored-by: Harry <[email protected]>
Co-authored-by: Shargon <[email protected]>

* Add `magic` field in getversion (neo-project#363)

* add magic field in getversion

* fix rpc client

* fix

* Fix validateaddress (neo-project#365)

* fix validateaddress

* apply recommendation

Co-authored-by: Owen Zhang <[email protected]>

* Allow rpc method can be overrided (neo-project#367)

* allow rpc method can be overrided

* change to protected virtual

* set DummyWallet private

* Update src/RpcServer/RpcServer.SmartContract.cs

Co-authored-by: Shargon <[email protected]>

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* Update RpcServer.Utilities.cs (neo-project#374)

* add null check for transferaddress (neo-project#373)

* add null check for transferaddress

* add ut

* fix ut

* fix format

* fix

* merge master

Co-authored-by: Owen Zhang <[email protected]>

* invoke* use base64 script (neo-project#362)

* invoke* use base64 script

* fix rpc client

* fix ut

* fix validateaddress

* fix ut

* revert

* fix ProcessInvokeWithWallet

Co-authored-by: Owen Zhang <[email protected]>

* Remove sender from invoke method (neo-project#368)

* remove sender from invoke method

* fix

* format

Co-authored-by: Owen Zhang <[email protected]>

* Add `exception` field in invokeresult (neo-project#364)

* add exception field in invokeresult

* fix rpc client

* fix

* fix show exception message

* fix

* fix

* fix: add try-catch for processInvokeWithWallet

* fix

* apply

* trigger github action

* Singers

* fix

Co-authored-by: Owen Zhang <[email protected]>

* [RpcClient] Optimization code. (neo-project#372)

* optimization code

* conflict resolution 2

* conflict resolution 3

* update

* Update RpcApplicationLog.cs

* Update RpcBlock.cs

* Update RpcBlockHeader.cs

* Optimize return

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* [RpcClient] Add processing of Any type to StackItemFromJson method. (neo-project#371)

* Update Utility.cs

* Update RpcTestCases.json

* update

Co-authored-by: Owen Zhang <[email protected]>

* Fix script convert in MakeTransaction(). (neo-project#382)

* Use Base64String on response of getrawtransaction (neo-project#383)

Use Base64String on response of getrawtransaction

* Unify to base64 (neo-project#384)

* Update RpcServer.SmartContract.cs (neo-project#386)

According to neo-project#368 (comment)

* [RpcClient] Policy API mismatch (neo-project#388)

* fixed-bug-1021

* Update src/RpcServer/RpcServer.SmartContract.cs

* 😂

* NEO3: RPC client Policy API mismatch

* update

* update

* update

* UT

* Format

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* [Sync to master] Unify base64 (neo-project#397)

* Unify base64 in SendRawTransaction and SubmitBlock

* fix GetRpcName() in GetWalletBalanceAsync

* add SubmitBlock

* add ProcessInvokeWithWallet

* Modify container in GetInvokeResult method (neo-project#390)

* fixed-bug-1021

* Update src/RpcServer/RpcServer.SmartContract.cs

* 😂

* Modify container in GetInvokeResult method

* .

* Update src/RpcServer/RpcServer.SmartContract.cs

Co-authored-by: cloud8little <[email protected]>

Co-authored-by: Shargon <[email protected]>
Co-authored-by: cloud8little <[email protected]>

* trigger type for getapplicationlog (neo-project#380)

* fixed-bug-1021

* Update src/RpcServer/RpcServer.SmartContract.cs

* 😂

* Keeping up to date with neo

* Keeping up to date with neo

* Revert "Keeping up to date with neo"

This reverts commit aa8e120.

* Prevent create key if not null

* dotnet format

* Query application log via blockhash

* update

* Modifying the Json storage structure

* Modifying the JSON storage structure 2

* Additional optional "trigger" parameter to getapplicationlog for clients to be able to get just one execution result for a block.

* Re-run checks

* StrictUTF8

* Update src/ApplicationLogs/LogReader.cs

Co-authored-by: Luchuan <[email protected]>

* Optimize

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Vitor Nazário Coelho <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* Update RpcApplicationLog.cs in RpcClient (neo-project#395)

* fixed-bug-1021

* Update src/RpcServer/RpcServer.SmartContract.cs

* 😂

* Update RpcApplicationLog.cs in RpcClient

* update

* Fixed UT

* ???

* update

* UT

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>
Co-authored-by: superboyiii <[email protected]>

* Update LogReader.cs (neo-project#401)

* Update LogReader.cs

* update

* [RpcServer] Update RpcServer.SmartContract.cs (neo-project#400)

* Update RpcServer.SmartContract.cs

* Update src/RpcServer/RpcServer.SmartContract.cs

Co-authored-by: Shargon <[email protected]>

* update

Co-authored-by: Owen Zhang <[email protected]>
Co-authored-by: Shargon <[email protected]>

* use shared directory.build.props file (neo-project#403)

* use shared directory.build.props file

* Update src/LevelDBStore/LevelDBStore.csproj

Co-authored-by: Erik Zhang <[email protected]>

* Update src/RocksDBStore/RocksDBStore.csproj

Co-authored-by: Erik Zhang <[email protected]>

* Update src/RocksDBStore/RocksDBStore.csproj

Co-authored-by: Erik Zhang <[email protected]>

* CR Feedback

* Fix namespace

Co-authored-by: Harry <[email protected]>
Co-authored-by: Erik Zhang <[email protected]>
Co-authored-by: Harry Pierson <[email protected]>

* create helper applog JSON functions for reuse in neo-express (neo-project#402)

* create helper applog JSON functions for reuse in neo-express

* Update LogReader.cs (neo-project#401)

* Update LogReader.cs

* update

Co-authored-by: Harry <[email protected]>

Co-authored-by: erikzhang <[email protected]>
Co-authored-by: Igor Machado Coelho <[email protected]>
Co-authored-by: hal0x2328 <[email protected]>
Co-authored-by: f27d <[email protected]>
Co-authored-by: belane <[email protected]>
Co-authored-by: Vitor Nazário Coelho <[email protected]>
Co-authored-by: Ricardo Prado <[email protected]>
Co-authored-by: jsolman <[email protected]>
Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>
Co-authored-by: zhangtao <[email protected]>
Co-authored-by: Celia18305 <[email protected]>
Co-authored-by: Krain Chen <[email protected]>
Co-authored-by: cn1010 <[email protected]>
Co-authored-by: Nicole <[email protected]>
Co-authored-by: cn1010 <[email protected]>
Co-authored-by: Qiao Jin <[email protected]>
Co-authored-by: Harry Pierson <[email protected]>
Co-authored-by: Harry Pierson <[email protected]>
Co-authored-by: ZhangHaoqiang <[email protected]>
Co-authored-by: superboyiii <[email protected]>
Co-authored-by: zhuoqian <[email protected]>
Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Luchuan <[email protected]>
Co-authored-by: joeqian <[email protected]>
Co-authored-by: cloud8little <[email protected]>
Co-authored-by: Jin Qiao <[email protected]>
Co-authored-by: Harry Pierson <[email protected]>
chenzhitong pushed a commit to chenzhitong/neo-modules that referenced this pull request Nov 25, 2020
* add SimplePolicy

* add ApplicationLogs

* use leveldb in ApplicationLogs

* update dependency: Neo v3.0.0-preview2-04

Close #1

* Logging in millisecs

After change to Akka consensus in NEO 3.0, it's so fast that seconds do not mean much anymore.. now milliseconds is important to actually know of what is going on the consensus algorithm.

* remove break statement from FilterFree

* Fix Priority Fee Transactions being treated as Free (#4)

* add RpcDisabled

* add StatesDumper

* add ImportBlocks (#7)

* `yield break` when the height of the imported block reaches the limit

* detect recursive references in ApplicationLogs

* exporting blocks in plugin

* copy config.json to output directory automatically

* v2.9.0 (#9)

* fix SimplePolicyPlugin

* fix neo-project/neo#395

* Rpc Basic Auth (#14)

* Rpc Basic Auth

* change plugin name to RpcSecurity

* Including number of dumped states (#17)

* Including number of dumped states

* Update StatesDumper/StatesDumper.cs

Co-Authored-By: vncoelho <[email protected]>

* Readme (#18)

* misspelling (#26)

* Help for Plugins (#28)

* Transaction size plugin (#10)

* Update packages reference (#22)

* Basic unit test structure for SimplePolicyPlugin (#25)

* Persitence Plugin for exporting storage changes (#21)

* Persitence Plugin first draft

* Fixing some compiling problems. Trackable is still not found in the local scope.

* Minnor changes. Trackable still not found

* Fixing all compiling errors and Trackable

* Fixing StorageKey and Item get values

* Switch case Persist Action and fixing Storage export

* Adding Height To Being

* Moving plugin to StatesDumper

* minnor comments

* remove StatesDumper.sln

* format

* remove `Settings.BlockStorageCache`

* add `PersistActions`

* v2.9.3 (#31)

* Update packages reference

* Fix claim (#34)

* v2.9.4

* Expose the max TX per block and max low priority TX per block. (neo-project#37)

* Ensure PoW correct order for TXs tiebreakers (neo-project#38)

* Ensure PoW correct order for TXs tiebreakers

* ThenByAscending for Hash

* Expose HighPriorityTxType (neo-project#39)

* Expose HighPriorityTxType

* HigherLowPriorityTxTypes

* InHigherLowPriorityList

* Modify missing InHigherLowPriorityList

* Missing InHigherLowPriorityList

* Use InHigherLowPriorityList and change to public

* Clean

* Clean II

* Commit as the final step of persistence in StatesDumper (neo-project#40)

* Support commit as the final step of persistence.

* Update for new method .

* OnCommitStorage

* Adding tests and fixing typo (neo-project#41)

* Adding tests and fixing typo

* adding random attribute to claim

* unit tests for hash compare

* Creating Travis CI for neo-plugins (neo-project#42)

* Including PreProcess and PostProcess functions (neo-project#46)

* Including PreProcess and PostProcess functions

* Adding pre-post to RpcSecurity

* Fix missing public declaration (neo-project#48)

* Add RpcWallet (neo-project#44)

* Add RpcWallet

* Add `importprivkey`

* Add `from` parameter to `sendmany`

* Add `getunclaimedgas`

* Add `claimgas`

* Add reference: Neo 2.10.0

* Fix `importprivkey`

* Add plugin for NEP5 balances and transfer history (Persistence + RPC) (neo-project#43)

* Check authentication during pre-processing. (neo-project#54)

* v2.10.0

* Fix memory leak of LevelDB snapshots. (neo-project#57)

* Use IPersistencePlugin and batch Application Log writes. (neo-project#62)

* Fix sizes for RpcNep5Tracker (neo-project#67)

* Plugin CoreMetrics (neo-project#68)

* Plugin coreMetrics.

* Organize project files

* metric prefix

* Make calculation for extra gas on "send*" RPC (neo-project#70)

* Make calculation for extra gas on "send*" RPC

* Fix for the calculation when little overstep

* Add Max_Fee as the optional for gas limit. (neo-project#74)

* Make calculation for extra gas on "send*" RPC (neo-project#70)

* Make calculation for extra gas on "send*" RPC

* Fix for the calculation when little overstep

* Delete the dependency which is for testing purpose

* Choose the max_fee between  fee and extra_fee

* Change error codes

* Update Settings.cs

* format

* Add `NuGet.Config`

* fix size calculation (neo-project#75)

* Add Plugin for UTXO tracking by account. (neo-project#65)

* Add Plugin for UTXO tracking by account.

* Rename RpcSystemAssetPlugin -> RpcSystemAssetTracker.

* Accept address or script hash.

* Remove unnecessary white space.

* Update project ref to Neo 2.10.1-CI00002.

* Ensure consistency in case of crash or kill.

* Fix setting lastPersistedBlock after each block is persisted.

* Performance optimization: Don't write block number for empty blocks.

* Optimize.

* Add support for tracking unclaimed spent outputs.

* Provide getclaimable RPC call for getting available claim spent outputs.

* Clean-up.

* Don't leak memory.

* Implement getclaimable to get get total unclaimed amount for an address.

* Remove unnecessary comment.

* Fix size of UserSystemAssetCoinOutputs. Remove unused using statement.

* Reload max utxo's from configuration if it changes.

* Upgrade dependency

* Fix .sln for neo-project#65

* Updating Readme information (neo-project#76)

* Fixes `ImportBlocks` for Neo 2.10.1 (neo-project#78)

* v2.10.1

* Properly stop importing blocks on system shutdown. (neo-project#66)

* RpcNep5Tracker: Handle NEP5 transfers to/from null & limit max results (neo-project#71)

* Handle NEP5 transfers to/from null.
* Add support for tracking tokens using non-standard mintToken event.
* Implement maximum results to return for transfer history.
* Make whether to support tracking null address history configurable. Default to false.
* Better input validation
* Support tracking non-standard mintTokens event, but default to off.

* Small optimization (neo-project#82)

* Updating travis (neo-project#84)

* Fix output json for multisigaddress transaction (neo-project#86)

* Fix output json for multisigaddress transaction 

Fix output json for multisigaddress transaction

* format

* format

* Fix the height to end with (neo-project#88)

* Fix-heightToEnd

* Minor fix and comment

* Minor fix on storage state dumper parameter HeightToStartRealTimeSyncing (neo-project#91)

* Minor fix on storage state dumper parameter HeightToStartRealTimeSyncing

* Update StatesDumper/StatesDumper.cs

Co-Authored-By: vncoelho <[email protected]>

* Prevent exceed the height (neo-project#92)

* Update CoreMetrics.cs

I think that it could be exceeded the max height using the `lastHeight` parameter

* Update CoreMetrics.cs

* v2.10.2 (neo-project#96)

* Update CoreMetrics.cs (neo-project#94)

* Update dependency: Neo v3.0.0-CI00044 (neo-project#98)

* Updating README - Removing Asset Tracker plugin (neo-project#104)

Removing description of asset tracker plugin from NEO 3.0 plugins readme

* Prevent DoS with wrong files (neo-project#81)

* Prevent DoS with wrong files

* Constant

* Throw exception

* Clean

* Fixing uint to ulong for some plugins due to seconds to ms change (neo-project#107)

* Fixing uint to ulong for some plugins

* Removing .sln files

* Updating nuget to more recent daily build

* Removing SimplePolicy plugin (neo-project#110)

* Clean SimplePolicy

* Removing travis

* Completely removing SimplePolicy

* Updating readme

* Re-adding travis

* Dotnet restore on Travis

* Cleaning .sln

* Cleaning SP-UT

* SystemLog plugin (neo-project#117)

* CI00151 (neo-project#111)

* Remove `mintTokens` from RpcNep5Tracker

* Fixes deadlock in RpcNep5Tracker (neo-project#128)

* Updating README with RPC Wallet and SystemLog (neo-project#126)

* Fix RpcNep5Tracker (neo-project#125)

* Fixes output of `getbalance` (neo-project#132)

* Fix/memory (neo-project#135)

* use Singleton.Store.GetBlock optimize memory cause

* refactor

* v3.0.0-preview1 (neo-project#136)

* Update to v3.0.0-preview1

* update version number

* Fix cell on maxNBlocksPerDay (3.X) (neo-project#142)

* Fix cell on maxNBlocksPerDay

uint (86400/15000*10000) equals 5000 but not 5760 because ```maxNBlocksPerDay``` is uint but not float.

* Delete incoverable code

Delete incoverable code since unint can't be <0,. For example: uint(-1) = uint 4294967295.

* Fix nBlocks == 0

Fix nBlocks == 0

* Upgrade dependencies and target frameworks (neo-project#147)

* Upgrade dependencies and target frameworks

* Update .travis.yml

* IStorage (neo-project#148)

* Fix UT (neo-project#149)

* Update RpcNep5Tracker/RpcNep5Tracker.cs

Co-Authored-By: Erik Zhang <[email protected]>

* Update RpcNep5Tracker/RpcNep5Tracker.cs

Co-Authored-By: Erik Zhang <[email protected]>

* Update RpcNep5Tracker/RpcNep5Tracker.cs

Co-Authored-By: Erik Zhang <[email protected]>

* Remove Travis and use Github Actions (neo-project#151)

* Fix SystemLog

* Add LevelDBStore (neo-project#150)

* Neo v3.0.0-CI00817

* Fix leveldb (neo-project#153)

* Fix ApplicationLog (neo-project#154)

* Dispose ApplicationEngine after using (neo-project#156)

* RocksDb storage plugin (neo-project#144)

* RocksDb plugin

* Update IStoragePlugin.cs

* Clean name

* Refactor as IStore

* Remove Helper

* Reorder

* Remove IStorage

* Reduce sln changes

* sln bom

* Clean and optimize

* Update nuget

* Create and cache only families if are used

* Rename namespaces

* Rename classes

* 3.0 version

* Format

* Rename the directory

* SetSync

* Remove the DbOptions wrapper

* Update Options.cs

* Remove RocksDBCore

* Remove ColumnFamily.cs

* Rename RocksDbSnapshot to Snapshot

* Add config.json

* Update RocksDBStore.csproj

* Add storage UT

* Fix RocksDb

* Update dotnetcore.yml

* Update dotnetcore.yml

* Copy fix leveldb

* Remove test

* Remove comment

* Fix the fix

* Fix Clear method

* Some changes

* Fix sln

* Update dotnetcore.yml

* sudo apt

* add leveldb

* Update dotnetcore.yml

* Fix Dispose and add UT

* Clean using

* Optimize LevelDB init

* Move projects to src (neo-project#159)

* Remove ImportBlocks (neo-project#161)

* Update .sln

* Rename tests

* Add RpcClient (neo-project#163)

* Remove CoreMetrics (neo-project#164)

* Coveralls (neo-project#165)

* Add RpcServer (neo-project#160)

* Update README.md (neo-project#146)

* Update NuGet versions of all modules (neo-project#174)

* Update-package-rpc-client

* Update nuget

* Update Crypto.ECDsaVerify

* Update TransactionManager.cs

* Some fixes

* Change from public to protected as in level db (neo-project#177)

* Change from public to protected as in level db

* Update RocksDBStore.csproj

Co-authored-by: Shargon <[email protected]>

* Update neo nuget

* change network fee calculation (neo-project#178)

* change network fee calculation

* update to CI00847

* fix fee issue

* add UT for network fee

* Update versions

* Update src/RpcClient/TransactionManager.cs

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Krain Chen <[email protected]>

* Rpc limits (3x) (neo-project#172)

* Add some limits to rpc

* Updating to peer and comments

* Allow to configure MaxConcurrentConnections

* Enter

Co-authored-by: Vitor Nazário Coelho <[email protected]>

* update readme (neo-project#169)

* update readme

* more details for rpc-related plugins

* desc for plugin dependency

* add logo

* Improvement

Improvement

* Delete --log

Delete --log

* Format

Format

* Minor changes

* Adding note about NEP5 functionalities

* Updating with RpcServer

* Fix

Fix

* Format

Format

* Remove StorageEngine

Remove StorageEngine

Co-authored-by: Owen Zhang <[email protected]>
Co-authored-by: Vitor Nazário Coelho <[email protected]>
Co-authored-by: Shargon <[email protected]>

* dotnet-format (neo-project#185)

* Fix

* Fix

* Add dotnet format version

* Fix version

* Update main.yml

* Update main.yml

* Update main.yml

* Fix RpcServer[GetStorage] (neo-project#183)

* Fix RpcServer.Blockchain.cs[GetStorage], using id to be key.

* Accept id and hash

Co-authored-by: Shargon <[email protected]>

* Update Neo nuget to 3.0.0-CI00855 (neo-project#186)

* Update Neo nuget to 3.0.0-CI00855

* update

update

* fix balance not change for non-transfer tx (neo-project#181)

* fix balance not change for non-transfer tx

* deal with gas burn seperately

* remove conversion to null

* check stackitem null

* Fix IsNull

* Remove nullable

* Use constant

* PR correction

* modify check statement

* bug ifix

* send stackitem.null

* not tracker non-tx transfer history

* format

* format

* add check for invalid address

Co-authored-by: Shargon <[email protected]>

* adapt RpcClient to modules (neo-project#171)

* adapt RpcClient to modules

* fix json issue

* fix size calculate

* Fix getnep5balances name issue

* add wallet rpc methods, reconstruct rpc UT

* PR correction

* move models to rpc server

* delete models from rpcclient

* change plugins with model

* format names

* move models back to rpc client

* fix build error

* change test file

* auto calculate network fee, update version

* format code

* fix issue #1416 Deal with ContractParameterType.Any

* change GetStorage parameter to enable id query

* add test for issue #1416

* PR correction

* use snake_case in json

* update neo version

* Update src/RpcClient/RpcClient.cs

Co-Authored-By: Shargon <[email protected]>

* Update src/RpcClient/RpcClient.cs

Co-Authored-By: Shargon <[email protected]>

* PR correction

* update neo version

Co-authored-by: Vitor Nazário Coelho <[email protected]>
Co-authored-by: Nicole <[email protected]>
Co-authored-by: Shargon <[email protected]>

* Deal with contract destory (neo-project#196)

* deal with contract destory

* remove delete key

* Remove GetBlockSysFee (neo-project#199)

* remove GetSysFeeAmount in rpcserver

* remove getblocksysfee in rpcclient

* fix ut

Co-authored-by: Vitor Nazário Coelho <[email protected]>

* ByteArray -> ByteString (neo-project#215)

* Change module command (neo-project#187)

* change command

* Change comment

* Add nuget

* Update StatesDumper.cs

* Fix RelayResult issue (neo-project#220)

* Add CheckWitness to func invokefunction (neo-project#214)

* remove round up sysfee (neo-project#219)

Co-authored-by: Vitor Nazário Coelho <[email protected]>

* Enable programmatic configuration of RpcServer plugin (neo-project#206)

* seperate out plugin from rpcServer functionality

* Update src/RpcServer/RpcServer.cs

* CR Feedback

* fix encoding

* fix build break

Co-authored-by: Harry Pierson <[email protected]>
Co-authored-by: Shargon <[email protected]>

* Fix SystemLog (neo-project#222)

* Update and consolidate nugets (neo-project#194)

* add multi-sig-transfer (neo-project#213)

* Update nugets (neo-project#226)

* Add StackItem ToJson (neo-project#221)

* Override RpcServerPlugin's name (neo-project#235)

* Fix RpcServer RegisterMethods (neo-project#239)

* Fix RpcServer RegisterMethods

* Update RpcServerPlugin.cs

OnPluginsLoaded() will do RegisterMethods

* Update nugets (neo-project#233)

* Close 232

* Sync to the latest neo.

* Fix UT

* Deal with exceptions

* Use last version

* Fix compilation

* Fix RPC module UTs.

Co-authored-by: superboyiii <[email protected]>
Co-authored-by: zhuoqian <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* Allow to share logs in read mode (neo-project#240)

* Allow to share logs in read mode

* Catch exception

* Update Logger.cs

* format

format

Co-authored-by: Owen Zhang <[email protected]>

* Create generic getunclaimedgas and rename wallet ones (neo-project#243)

* Create generic getunclaimedgas and rename wallet ones

* Throw exception

* fix relay tx (neo-project#249)

* add issue template (neo-project#250)

* delete systemlog plugin (neo-project#246)

Co-authored-by: Shargon <[email protected]>

* Add plugin desc and fix ut (neo-project#257)

* add plugin desc and sync neo-core

* format

Co-authored-by: Vitor Nazário Coelho <[email protected]>

* Convert StackItem directly to json (neo-project#264)

* Change json field names for GetVersion (neo-project#262)

Co-authored-by: Shargon <[email protected]>

* remove system log (neo-project#272)

* Neo.VM.3.0.0-CI00958 (neo-project#274)

* fix

* fix event

* CI00958

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Erik Zhang <[email protected]>

* Add EventName to NotifyEventArgs (neo-project#267)

* Add EventName to NotifyEventArgs

* Update UT cases

* Change to all lower case

* Fix UTs

* Fix format

* Fix format again

* Replace db.Find by db.Seek (neo-project#279)

* replace find by seek

* add db.seek

* fix

* format

Co-authored-by: Luchuan <[email protected]>

* Add a generic GetUnclaimedGas() in RpcClient (neo-project#273)

* Add GetUnclaimedGas() in RpcClient and UT

* Fix format

* Update tests/Neo.Network.RPC.Tests/RpcTestCases.json

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Shargon <[email protected]>

* Fix seek (neo-project#281)

* fix seek

* move Helper method

* Update Helper.cs

Co-authored-by: Luchuan <[email protected]>

* Change json fields to all lower case for consistency (neo-project#277)

* Change json field names for GetVersion

* Change json fields to snake case for consistency

* Change json fields to all lower case

* Fix UTs.

* rename

* Add back GetUnclaimedGas()

* Remove "_" in RpcNep5Tracker.cs

* Remove underscore line

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Luchuan <[email protected]>

* fix add signature in invokefunction and invokescript (neo-project#280)

* fix add signature in invokefunction and invokescript

* Update RpcServer.SmartContract.cs

* rename

* fix format

* add exception if wallet or cosigners is null

* Set the default tx to null

Co-authored-by: Shargon <[email protected]>

* update nuget (neo-project#283)

* update nuget

* remove GasFree

* resolve conflict

Co-authored-by: Owen Zhang <[email protected]>

* update IStorageProvider (neo-project#285)

* update signers for invokefunction and invokescript (neo-project#286)

* update signers for invokefunction and invokescript

* fix format

* Validate signer format

Co-authored-by: Shargon <[email protected]>

* Add BloomFilter to levelDB (neo-project#253)

* Add BloomFilter to levelDB

* Code optimization

* Code optimization

* Optimize bloomfilter bits per key value

* Hard-code bloomfilter bitsPeyKey to 15

* Code optimization

Co-authored-by: Jin Qiao <[email protected]>
Co-authored-by: Shargon <[email protected]>
Co-authored-by: Erik Zhang <[email protected]>

* Solve workflow conflict (neo-project#294)

* Solve workflow conflict

Solve workflow conflict from master-2.x and master

* Update main.yml

Apply neo-project/neo#1775

Co-authored-by: Shargon <[email protected]>

* update InvokeFunction (neo-project#295)

* Fix db.Seek (neo-project#291)

* add db.seek ut

* fix db.seek

* remove ByteArrayCompare

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Shargon <[email protected]>

* update RpcClient (neo-project#296)

* update RpcClient

* fix sln

* fix format

* fix format

Co-authored-by: Owen Zhang <[email protected]>

* Add Utility.StackItemFromJson (neo-project#302)

* fix invoke tojson

* add StackItemFromJson

* optimize code

* remove src/RpcClientTests/UtilityTests.cs

Co-authored-by: Luchuan <[email protected]>

* Merge Preview3 to Master (neo-project#307)

* Add Utility.StackItemFromJson (neo-project#302) (neo-project#303)

* fix invoke tojson

* add StackItemFromJson

* optimize code

* remove src/RpcClientTests/UtilityTests.cs

Co-authored-by: Luchuan <[email protected]>

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Luchuan <[email protected]>

* update to preview3 (neo-project#305)

Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Luchuan <[email protected]>

* fix neo-project#312 (neo-project#319)

* Allow to try to repair leveldb before opening (neo-project#322)

* update applicationLogs serialization (neo-project#321)

* Remove old bug (neo-project#331)

* Optimize RocksDb startup (neo-project#333)

* Fix RocksDb (neo-project#332)

* Add Getcommittee (neo-project#342)

* update signers and add sender for rpc api (neo-project#309)

* Optimize the result of 'getnep5transfers' (neo-project#345)

* Update RpcNep5Tracker.cs

* Update RpcNep5Tracker.cs

Co-authored-by: Erik Zhang <[email protected]>

* Allow querying contracts by name (neo-project#340)

* Update dependencies (neo-project#338)

* Neo 3.0.0-CI01036 (neo-project#353)

* upgrade neo-core

* Add statesdumper

Co-authored-by: Shargon <[email protected]>

* Replace getvalidators by getnextblockvalidators (neo-project#366)

* Pure async RpcClient (neo-project#335)

* compiling, some stuff stubbed out

* more tests working

* MakeTxContext

* mistake in GetBlock/GetBlockHeader

* rework TransactionManager to be closer to original

* more unit tests (2 still failing)

* remove assertEx

* Add ThrowsAsync comment

* ReturnsAsync

* fixed last remaining test issues

* minor TXManager cleanup

* formatting

* move tx contruction to MakeTransaction

* discards

* Async Suffixes (PR feedback)

* GetCommitteeAsync

* add custom magic support to tx manager

* fix format

* add magic param comment

* CR Feedback

* Clean enter

Co-authored-by: Harry <[email protected]>
Co-authored-by: Shargon <[email protected]>

* Add `magic` field in getversion (neo-project#363)

* add magic field in getversion

* fix rpc client

* fix

* Fix validateaddress (neo-project#365)

* fix validateaddress

* apply recommendation

Co-authored-by: Owen Zhang <[email protected]>

* Allow rpc method can be overrided (neo-project#367)

* allow rpc method can be overrided

* change to protected virtual

* set DummyWallet private

* Update src/RpcServer/RpcServer.SmartContract.cs

Co-authored-by: Shargon <[email protected]>

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* Update RpcServer.Utilities.cs (neo-project#374)

* add null check for transferaddress (neo-project#373)

* add null check for transferaddress

* add ut

* fix ut

* fix format

* fix

* merge master

Co-authored-by: Owen Zhang <[email protected]>

* invoke* use base64 script (neo-project#362)

* invoke* use base64 script

* fix rpc client

* fix ut

* fix validateaddress

* fix ut

* revert

* fix ProcessInvokeWithWallet

Co-authored-by: Owen Zhang <[email protected]>

* Remove sender from invoke method (neo-project#368)

* remove sender from invoke method

* fix

* format

Co-authored-by: Owen Zhang <[email protected]>

* Add `exception` field in invokeresult (neo-project#364)

* add exception field in invokeresult

* fix rpc client

* fix

* fix show exception message

* fix

* fix

* fix: add try-catch for processInvokeWithWallet

* fix

* apply

* trigger github action

* Singers

* fix

Co-authored-by: Owen Zhang <[email protected]>

* [RpcClient] Optimization code. (neo-project#372)

* optimization code

* conflict resolution 2

* conflict resolution 3

* update

* Update RpcApplicationLog.cs

* Update RpcBlock.cs

* Update RpcBlockHeader.cs

* Optimize return

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* [RpcClient] Add processing of Any type to StackItemFromJson method. (neo-project#371)

* Update Utility.cs

* Update RpcTestCases.json

* update

Co-authored-by: Owen Zhang <[email protected]>

* Fix script convert in MakeTransaction(). (neo-project#382)

* Use Base64String on response of getrawtransaction (neo-project#383)

Use Base64String on response of getrawtransaction

* Unify to base64 (neo-project#384)

* Update RpcServer.SmartContract.cs (neo-project#386)

According to neo-project#368 (comment)

* [RpcClient] Policy API mismatch (neo-project#388)

* fixed-bug-1021

* Update src/RpcServer/RpcServer.SmartContract.cs

* 😂

* NEO3: RPC client Policy API mismatch

* update

* update

* update

* UT

* Format

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* [Sync to master] Unify base64 (neo-project#397)

* Unify base64 in SendRawTransaction and SubmitBlock

* fix GetRpcName() in GetWalletBalanceAsync

* add SubmitBlock

* add ProcessInvokeWithWallet

* Modify container in GetInvokeResult method (neo-project#390)

* fixed-bug-1021

* Update src/RpcServer/RpcServer.SmartContract.cs

* 😂

* Modify container in GetInvokeResult method

* .

* Update src/RpcServer/RpcServer.SmartContract.cs

Co-authored-by: cloud8little <[email protected]>

Co-authored-by: Shargon <[email protected]>
Co-authored-by: cloud8little <[email protected]>

* trigger type for getapplicationlog (neo-project#380)

* fixed-bug-1021

* Update src/RpcServer/RpcServer.SmartContract.cs

* 😂

* Keeping up to date with neo

* Keeping up to date with neo

* Revert "Keeping up to date with neo"

This reverts commit aa8e120.

* Prevent create key if not null

* dotnet format

* Query application log via blockhash

* update

* Modifying the Json storage structure

* Modifying the JSON storage structure 2

* Additional optional "trigger" parameter to getapplicationlog for clients to be able to get just one execution result for a block.

* Re-run checks

* StrictUTF8

* Update src/ApplicationLogs/LogReader.cs

Co-authored-by: Luchuan <[email protected]>

* Optimize

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Vitor Nazário Coelho <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>

* Update RpcApplicationLog.cs in RpcClient (neo-project#395)

* fixed-bug-1021

* Update src/RpcServer/RpcServer.SmartContract.cs

* 😂

* Update RpcApplicationLog.cs in RpcClient

* update

* Fixed UT

* ???

* update

* UT

Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>
Co-authored-by: superboyiii <[email protected]>

* Update LogReader.cs (neo-project#401)

* Update LogReader.cs

* update

* [RpcServer] Update RpcServer.SmartContract.cs (neo-project#400)

* Update RpcServer.SmartContract.cs

* Update src/RpcServer/RpcServer.SmartContract.cs

Co-authored-by: Shargon <[email protected]>

* update

Co-authored-by: Owen Zhang <[email protected]>
Co-authored-by: Shargon <[email protected]>

* use shared directory.build.props file (neo-project#403)

* use shared directory.build.props file

* Update src/LevelDBStore/LevelDBStore.csproj

Co-authored-by: Erik Zhang <[email protected]>

* Update src/RocksDBStore/RocksDBStore.csproj

Co-authored-by: Erik Zhang <[email protected]>

* Update src/RocksDBStore/RocksDBStore.csproj

Co-authored-by: Erik Zhang <[email protected]>

* CR Feedback

* Fix namespace

Co-authored-by: Harry <[email protected]>
Co-authored-by: Erik Zhang <[email protected]>
Co-authored-by: Harry Pierson <[email protected]>

* create helper applog JSON functions for reuse in neo-express (neo-project#402)

* create helper applog JSON functions for reuse in neo-express

* Update LogReader.cs (neo-project#401)

* Update LogReader.cs

* update

Co-authored-by: Harry <[email protected]>

Co-authored-by: erikzhang <[email protected]>
Co-authored-by: Igor Machado Coelho <[email protected]>
Co-authored-by: hal0x2328 <[email protected]>
Co-authored-by: f27d <[email protected]>
Co-authored-by: belane <[email protected]>
Co-authored-by: Vitor Nazário Coelho <[email protected]>
Co-authored-by: Ricardo Prado <[email protected]>
Co-authored-by: jsolman <[email protected]>
Co-authored-by: Shargon <[email protected]>
Co-authored-by: Owen Zhang <[email protected]>
Co-authored-by: zhangtao <[email protected]>
Co-authored-by: Celia18305 <[email protected]>
Co-authored-by: Krain Chen <[email protected]>
Co-authored-by: cn1010 <[email protected]>
Co-authored-by: Nicole <[email protected]>
Co-authored-by: cn1010 <[email protected]>
Co-authored-by: Qiao Jin <[email protected]>
Co-authored-by: Harry Pierson <[email protected]>
Co-authored-by: Harry Pierson <[email protected]>
Co-authored-by: ZhangHaoqiang <[email protected]>
Co-authored-by: superboyiii <[email protected]>
Co-authored-by: zhuoqian <[email protected]>
Co-authored-by: Luchuan <[email protected]>
Co-authored-by: Luchuan <[email protected]>
Co-authored-by: joeqian <[email protected]>
Co-authored-by: cloud8little <[email protected]>
Co-authored-by: Jin Qiao <[email protected]>
Co-authored-by: Harry Pierson <[email protected]>
joeqian10 pushed a commit to joeqian10/neo-modules that referenced this pull request Apr 7, 2021
* remove sender from invoke method

* fix

* format

Co-authored-by: Owen Zhang <[email protected]>
joeqian10 pushed a commit to joeqian10/neo-modules that referenced this pull request Apr 7, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Remove sender from invoke* RPCs
7 participants