-
Notifications
You must be signed in to change notification settings - Fork 1k
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
[Neo Core Fix] Check params at Calling Contract #3438
base: HF_Echidna
Are you sure you want to change the base?
Changes from all commits
f26303a
ad33527
c01ac8f
9f394f3
01ed4dc
bb6692b
5aa0d30
df39d45
9ced170
e0328e3
c531917
e0edd98
3669912
692cfbb
71aac33
d749eaf
4c052ff
707dbd4
c086661
61de3a4
0f1507f
9e183fc
4d1c6bd
8da7163
3bb2012
8a9bbc5
6b25105
c13c9d6
120f7d3
5e53ee4
9c0770e
32507a9
6ff0356
f83e4f3
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,6 @@ | ||
FROM mcr.microsoft.com/devcontainers/dotnet:9.0-noble | ||
# https://github.com/dotnet/dotnet-docker/blob/main/README.sdk.md | ||
# https://mcr.microsoft.com/en-us/artifact/mar/dotnet/sdk/tags <-- this shows all images | ||
FROM mcr.microsoft.com/dotnet/sdk:9.0.101-noble | ||
|
||
# Install the libleveldb-dev package | ||
RUN apt-get update && apt-get install -y libleveldb-dev |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
// Copyright (C) 2015-2024 The Neo Project. | ||
// | ||
// GasTokenExtensions.cs file belongs to the neo project and is free | ||
// software distributed under the MIT software license, see the | ||
// accompanying file LICENSE in the main directory of the | ||
// repository or http://www.opensource.org/licenses/mit-license.php | ||
// for more details. | ||
// | ||
// Redistribution and use in source and binary forms with or without | ||
// modifications are permitted. | ||
|
||
using Neo.Persistence; | ||
using Neo.SmartContract; | ||
using Neo.SmartContract.Native; | ||
using System; | ||
using System.Collections.Generic; | ||
using System.Numerics; | ||
|
||
namespace Neo.Extensions | ||
{ | ||
public static class GasTokenExtensions | ||
{ | ||
public static IEnumerable<(UInt160 Address, BigInteger Balance)> GetAccounts(this GasToken gasToken, DataCache snapshot) | ||
{ | ||
if (gasToken is null) | ||
throw new ArgumentNullException(nameof(gasToken)); | ||
|
||
if (snapshot is null) | ||
throw new ArgumentNullException(nameof(snapshot)); | ||
|
||
var kb = new KeyBuilder(gasToken.Id, GasToken.Prefix_Account); | ||
var prefixKey = kb.ToArray(); | ||
|
||
foreach (var (key, value) in snapshot.Find(prefixKey, SeekDirection.Forward)) | ||
{ | ||
var keyBytes = key.ToArray(); | ||
var addressHash = new UInt160(keyBytes.AsSpan(prefixKey.Length)); | ||
yield return new(addressHash, value.GetInteroperable<AccountState>().Balance); | ||
} | ||
} | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -325,7 +325,11 @@ private ExecutionContext CallContractInternal(ContractState contract, ContractMe | |
state.CallingContext = currentContext; | ||
|
||
for (int i = args.Count - 1; i >= 0; i--) | ||
{ | ||
if (!CheckItemType(args[i], method.Parameters[i].Type)) | ||
throw new InvalidOperationException($"The type of the argument `{args[i]}` does not match the formal parameter."); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It may be too harsh for mainnet contracts (even if enabled with hardfrok), this change may break some of them and even prevent them from update. What do you think about using the same approach as it was done for SC Events parameters check (#2810 (comment)): in next release we firstly enable a warning log in case of parameters mismatch, and then in the subsequent release we convert the log to an exception. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
We have discussed this in the last meeting, check will only happen for newly deployed or updated contracts, this pr will be updated. |
||
context_new.EvaluationStack.Push(args[i]); | ||
} | ||
|
||
return context_new; | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think it's correct for VM-compatible SC types, because for example, if you require stackitem to be Boolean, then Any just doesn't match this requirement.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see what you mean, will update.