FrostFS smart-contract
Find a file
Evgenii Stratonikov 6212b5bf72
Some checks failed
/ DCO (pull_request) Failing after 3s
/ Tests (1.19) (pull_request) Successful in 5m10s
/ Tests (1.20) (pull_request) Successful in 53s
[#42] container: Make GAS costs more predictable in Delete()
Persisting a transaction is done in 2 stages:
1. TestInvoke
2. Sign and send to the network.
3. At some point the tx is persisted.
Some time passes between 1 and 3, this could lead to different GAS
costs. It is a known issue for container delete: different epoch can
have different size in bytes and thus different cost to store.
Here we introduce fixed-length encoding for integers, so that the
problem can be avoided.

Signed-off-by: Evgenii Stratonikov <e.stratonikov@yadro.com>
2023-10-05 15:49:06 +03:00
.forgejo/workflows [#38] .forgejo: Update DCO action 2023-08-17 15:31:34 +03:00
.github [#32] Add forgejo workflows 2023-06-27 16:47:46 +03:00
alphabet [#10] Use UpdateWithData call wrapper in Update methods 2023-06-19 11:17:51 +03:00
audit [#10] Use UpdateWithData call wrapper in Update methods 2023-06-19 11:17:51 +03:00
balance *: Use multiline lists in yaml config 2023-08-10 17:13:07 +00:00
common [#42] common: Add routines for fixed-width uint64 marshaling 2023-10-05 15:10:04 +03:00
container [#42] container: Make GAS costs more predictable in Delete() 2023-10-05 15:49:06 +03:00
debian [#20] subnet: Drop contract 2023-04-17 14:29:30 +03:00
frostfs *: Use multiline lists in yaml config 2023-08-10 17:13:07 +00:00
frostfsid [#10] Use UpdateWithData call wrapper in Update methods 2023-06-19 11:17:51 +03:00
netmap *: Use multiline lists in yaml config 2023-08-10 17:13:07 +00:00
nns *: Use multiline lists in yaml config 2023-08-10 17:13:07 +00:00
processing [#10] Use UpdateWithData call wrapper in Update methods 2023-06-19 11:17:51 +03:00
proxy [#10] Use UpdateWithData call wrapper in Update methods 2023-06-19 11:17:51 +03:00
reputation [#10] Use UpdateWithData call wrapper in Update methods 2023-06-19 11:17:51 +03:00
tests [#42] container: Make GAS costs more predictable in Delete() 2023-10-05 15:49:06 +03:00
.gitignore [#291] Debian packaging 2023-01-16 14:40:21 +03:00
CHANGELOG.md Release v0.18.0 2023-09-14 13:33:12 +03:00
go.mod go.mod: Update neo-go 2023-08-09 10:09:18 +03:00
go.sum go.mod: Update neo-go 2023-08-09 10:09:18 +03:00
LICENSE.md init commit 2020-04-01 19:27:29 +03:00
Makefile [#20] subnet: Drop contract 2023-04-17 14:29:30 +03:00
README.md [#20] subnet: Drop contract 2023-04-17 14:29:30 +03:00
VERSION [#19] common: Update current version 2023-04-13 11:24:52 +03:00

FrostFS

FrostFS related smart contracts.


Overview

FrostFS-Contract contains all FrostFS related contracts written for neo-go compiler. These contracts are deployed both in the mainchain and the sidechain.

Mainchain contracts:

  • frostfs
  • processing

Sidechain contracts:

  • alphabet
  • audit
  • balance
  • container
  • frostfsid
  • netmap
  • nns
  • proxy
  • reputation

Getting started

Prerequisites

To compile smart contracts you need:

Compilation

To build and compile smart contract, run make all command. Compiled contracts *_contract.nef and manifest config.json files are placed in the corresponding directories.

$ make all
/home/user/go/bin/cli contract compile -i alphabet -c alphabet/config.yml -m alphabet/config.json -o alphabet/alphabet_contract.nef
/home/user/go/bin/cli contract compile -i audit -c audit/config.yml -m audit/config.json -o audit/audit_contract.nef
/home/user/go/bin/cli contract compile -i balance -c balance/config.yml -m balance/config.json -o balance/balance_contract.nef
/home/user/go/bin/cli contract compile -i container -c container/config.yml -m container/config.json -o container/container_contract.nef
/home/user/go/bin/cli contract compile -i frostfsid -c frostfsid/config.yml -m frostfsid/config.json -o frostfsid/frostfsid_contract.nef
/home/user/go/bin/cli contract compile -i netmap -c netmap/config.yml -m netmap/config.json -o netmap/netmap_contract.nef
/home/user/go/bin/cli contract compile -i proxy -c proxy/config.yml -m proxy/config.json -o proxy/proxy_contract.nef
/home/user/go/bin/cli contract compile -i reputation -c reputation/config.yml -m reputation/config.json -o reputation/reputation_contract.nef
/home/user/go/bin/cli contract compile -i nns -c nns/config.yml -m nns/config.json -o nns/nns_contract.nef
/home/user/go/bin/cli contract compile -i frostfs -c frostfs/config.yml -m frostfs/config.json -o frostfs/frostfs_contract.nef
/home/user/go/bin/cli contract compile -i processing -c processing/config.yml -m processing/config.json -o processing/processing_contract.nef

You can specify path to the neo-go binary with NEOGO environment variable:

$ NEOGO=/home/user/neo-go/bin/neo-go make all

Remove compiled files with make clean or make mr_proper command.

Building Debian package

To build Debian package containing compiled contracts, run make debpackage command. Package will install compiled contracts *_contract.nef and manifest config.json with corresponding directories to /var/lib/neofs/contract for further usage. It will download and build neo-go, if needed.

To clean package-related files, use make debclean.

Testing

Smartcontract tests reside in tests/ directory. To execute test suite after applying changes, simply run make test.

$ make test
ok      git.frostfs.info/TrueCloudLab/frostfs-contract/tests       0.462s

License

This project is licensed under the GPLv3 License - see the LICENSE.md file for details