WIP: FrostFS smart-contract
Find a file
Leonard Lyubich f9f2a03078 [#42] Share ballot structure between contracts
Create common package. Define Ballot struct in common package. Use new type
in all contracts with ballots.

Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
2021-02-04 10:31:24 +03:00
.github [#18] Update README file 2020-10-27 17:33:56 +03:00
alphabet [#42] Share ballot structure between contracts 2021-02-04 10:31:24 +03:00
audit [#28] audit: Add version offset in AuditResult binary 2020-12-29 14:24:52 +03:00
balance [#42] Share ballot structure between contracts 2021-02-04 10:31:24 +03:00
common [#42] Share ballot structure between contracts 2021-02-04 10:31:24 +03:00
container [#42] Share ballot structure between contracts 2021-02-04 10:31:24 +03:00
neofs [#42] Share ballot structure between contracts 2021-02-04 10:31:24 +03:00
neofsid [#42] Share ballot structure between contracts 2021-02-04 10:31:24 +03:00
netmap [#42] Share ballot structure between contracts 2021-02-04 10:31:24 +03:00
reputation [#18] Add sidechain contracts 2020-10-27 17:33:56 +03:00
.gitignore [#18] Ignore contracts config.json files 2020-10-27 17:33:56 +03:00
go.mod [#23] Update neo-go version 2020-12-29 14:15:26 +03:00
go.sum [#23] Update neo-go version 2020-12-29 14:15:26 +03:00
LICENSE.md init commit 2020-04-01 19:27:29 +03:00
Makefile [#23] alphabet: Use single contract instead of template 2020-12-29 14:15:26 +03:00
README.md Update README file 2020-12-29 14:32:37 +03:00

NeoFS

NeoFS related smart contracts.


Overview

NeoFS-Contract contains all NeoFS related contracts written for neo-go compiler. These contracts are deployed both in mainnet and sidechain.

Mainnet contract:

  • neofs

Sidechain contracts:

  • alphabet
  • audit
  • balance
  • container
  • neofsid
  • netmap
  • 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
neo-go contract compile -i alphabet/alphabet_contract.go -c alphabet/config.yml -m alphabet/config.json
neo-go contract compile -i audit/audit_contract.go -c audit/config.yml -m audit/config.json
neo-go contract compile -i balance/balance_contract.go -c balance/config.yml -m balance/config.json
neo-go contract compile -i container/container_contract.go -c container/config.yml -m container/config.json
neo-go contract compile -i neofsid/neofsid_contract.go -c neofsid/config.yml -m neofsid/config.json
neo-go contract compile -i netmap/netmap_contract.go -c netmap/config.yml -m netmap/config.json
neo-go contract compile -i reputation/reputation_contract.go -c reputation/config.yml -m reputation/config.json
neo-go contract compile -i neofs/neofs_contract.go -c neofs/config.yml -m neofs/config.json

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.

License

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