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

Reserve some TransactionAttributeTypes for experimental/private usage #1904

Open
roman-khimov opened this issue Sep 3, 2020 · 9 comments
Open
Labels
Discussion Initial issue state - proposed but not yet accepted

Comments

@roman-khimov
Copy link
Contributor

Summary or problem description
Many protocol-related experiments and extensions around transactions can start as simple attributes. Some private networks may also want to have extensions based on attributes for their internal usage. We have TransactionAttributeType and associated logic that regulates attributes, but at the moment it's not really encouraging these experiments as any type code might get used by the official node and decoding unknown attribute will always fail.

Do you have any solution you want to propose?

  1. Specify a reserved range of attribute types (for example, 224-255) that could be used for experiments and private networks. These would only be compatible between nodes that support them and may differ from node to node, but official Neo node would never use them.
    That costs nothing and I think we can do it easily.
  2. Add an option to allow reserved attributes on the network. For nodes that don't support some particular attribute that would just mean that they won't fail decoding it and will forward transactions containing them as usual. Nodes that support this attribute can use it for whatever purpose they want to. For mainnet this option will always be disabled (it's not for experiments). For testnet we can enable it and get an additional ability for broader experimentation without breaking the network.
    This is a bit more invasive and dangerous (think of two nodes using the same type but with a different meaning for it), but for testing purposes maybe it's worth it.

Neo Version

  • Neo 3

Where in the software does this update applies to?

  • P2P (TCP)
@roman-khimov roman-khimov added the Discussion Initial issue state - proposed but not yet accepted label Sep 3, 2020
@roman-khimov
Copy link
Contributor Author

Add an option to allow reserved attributes on the network

That would imply VarBytes encoding for reserved attribute's data, probably.

@roman-khimov
Copy link
Contributor Author

There is a prototype now implemented in nspcc-dev/neo-go#1496, 0xe0-0xff range is used for that.

@ZhangTao1596
Copy link

ZhangTao1596 commented Feb 22, 2022

We can add ExtensionAttribute with VarBytes payload and multiple allowed. Users can deserialize the payload to the structure they want.

@shargon
Copy link
Member

shargon commented Feb 22, 2022

Attributes are not exposed to SmartContracts, isn't it?

@ZhangTao1596
Copy link

Attributes are not exposed to SmartContracts, isn't it?

No, they aren't. https://github.com/neo-project/neo-devpack-dotnet/blob/master/src/Neo.SmartContract.Framework/Services/Transaction.cs

@shargon
Copy link
Member

shargon commented Feb 24, 2022

What's the sense if is not possible to use in a smart contract

@roman-khimov
Copy link
Contributor Author

Experimental protocol extensions of various sorts. Attributes we have now mostly affect P2P/validation/mempool behavior, contracts don't care about this, same thing with #1991 or #1992.

@erikzhang
Copy link
Member

erikzhang commented Mar 2, 2022

We can add ExtensionAttribute with VarBytes payload and multiple allowed. Users can deserialize the payload to the structure they want.

Do you agree on this solution? @roman-khimov

@roman-khimov
Copy link
Contributor Author

That essentially means using one attribute type for all potential extensions which requires further demultiplexing in practice. Could be done, but a range of attributes seems to be a bit more natural.

roman-khimov added a commit to roman-khimov/neo that referenced this issue Dec 21, 2024
Similar to TransactionAttributeTypes (neo-project#1904), we should have some reserved
values.

Signed-off-by: Roman Khimov <[email protected]>
NGDAdmin pushed a commit that referenced this issue Dec 25, 2024
* Capabilities: rephrase FullNode

FullNode is used by all proper nodes currently whether they drop old chain
data or not. It'd be more correct to define it as "having complete state"
rather than "having all blocks" since the latter is what ArchivalNode will
provide. This is also relevant wrt how this capability is used, see RemoteNode
OnRelay() and OnSend(). Refs #2346.

Signed-off-by: Roman Khimov <[email protected]>

* Capabilities: reserve 0xf0-0xff region for private experiments

Similar to TransactionAttributeTypes (#1904), we should have some reserved
values.

Signed-off-by: Roman Khimov <[email protected]>

* Capabilities: make them really extensible

The way capabilities are currently defined makes them very hard to extend
since old nodes will treat unknown types as invalid ones failing Version
decoding completely. To be able to ignore these types we should also have
more uniform encoding for unknown/new types.

Signed-off-by: Roman Khimov <[email protected]>

* Capabilities: introduce ArchivalNode

This will be used to differente full history nodes from state only. Currently
it's just a definition, we can not use it safely on current networks because
nodes will refuse this Version, so actual code using the attribute will be
added in newer versions.

Signed-off-by: Roman Khimov <[email protected]>

---------

Signed-off-by: Roman Khimov <[email protected]>
Co-authored-by: Shargon <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Discussion Initial issue state - proposed but not yet accepted
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants