diff --git a/INSTALL.md b/INSTALL.md new file mode 100644 index 0000000..b022074 --- /dev/null +++ b/INSTALL.md @@ -0,0 +1,54 @@ +# Building DeFinery + +As discussed in the [README](.README.md), the easiest way to run DeFinery is using a public Docker image. +The tool, however, can also be installed locally using the source code and a binary contained in this repository. This can be done in two ways: using Docker or building the tool directly in your system locally. In both cases, the installation may take up to 50 minutes, since some of the project dependencies (Z3, in particular) take quite long to install. + +## Prerequisites + +To build a Docker image for DeFinery, we have used Docker 20.10.14 that can be obtained from the Docker [website](https://docs.docker.com/get-docker/). + +The script provided in this repository were evaluated on Ubuntu 18:04. The binary of a symbolic execution component ([definery-see.zip](./definery-see.zip)) is also built for Linux-AMD64 (Ubuntu 18.04). + +DeFinery also uses Python 3.7 and Node v14.20.0. + + +## Dockerization + +The first way to build DeFinery locally is build a Docker image from the code contained in this repository. This can be done using the provided [Dockerfile](./Dockerfile) in the following way: +``` +# Creating an image called DeFinery +docker build -t definery . +``` + +Once the image is created, you can verify the tool installation by repairing one of the smart contracts used for the evaluation, e.g., +``` +docker run -it --rm -v ~/Desktop/test:/experiments/ definery Unprotected +``` + +`~/Desktop/test:/experiments/` mounts a local folder (`/Desktop/test`) to the Docker container to facilitate the exploration of patched smart contracts—you can, then, view the results produced by the tool in this folder. + +## Local Build + +As an alternative to using Docker, you can also build the tool locally. +We have prepared a one-click script that performs the installation of the tool and its dependencies to your system (the script is tested on Ubuntu 18:04). +The script installs the necessary C++, Python, and Node dependencies (build-essential, libboost-all-dev, cmake, curl, zip, unzip, tar, vcpkg, Z3, nvm). It assumes that Python 3.7, pip, and Git are installed in the system — if not, please uncomment their installation in the script. It also unpacks the binary of `definery-see` from the archive and moves it to the `/SCRepair` folder. Both components in DeFinery are configured to read and write files from/to `./contracts/` (we move the contracts from `/contracts/eval` there) and `./experiments` folders located within `/SCRepair`. The script also builds the repair module of DeFinery using `npm`. + +You can run the script as follows: + +``` +# install dependencies of the artifact and build the project +bash ./build.sh +``` + +To make sure that both symbolic-execution and repair components work as expected, you may run the following two commands in the provided order: +``` +cd SCRepair + +# Performing symbolic analysis of the Unprotected smart contract +# Results of the analysis should be saved in the ./experiments/Unprotected folder +./definery-see -symexe-main ./contracts/Unprotected.sol Unprotected + +# Based on the results of symbolic analysis, repair the smart contract +# The patched version of the contract should be saved in the ./experiments/Unprotected/patched folder +python3.7 ./CLI.py --targetContractName Unprotected repair ./experiments/Unprotected/Unprotected.sol +``` \ No newline at end of file diff --git a/SCRepair/CR.py b/SCRepair/CR.py index 21388b9..ad589df 100644 --- a/SCRepair/CR.py +++ b/SCRepair/CR.py @@ -543,8 +543,8 @@ async def repair(self, stdout = data_stdout.decode(utf_8.getregentry().name) output = stdout - if ignoreVar: - print(output) + # if ignoreVar: + # print(output) if "EQUIVALENT" in output: if "Not Equivalent" in output: diff --git a/SCRepair/README.md b/SCRepair/README.md index b92b6f4..00de2f5 100644 --- a/SCRepair/README.md +++ b/SCRepair/README.md @@ -26,7 +26,7 @@ Use the following command python3 CLI.py --targetContractName CONTRACT_NAME repair PATH_TO_CONTRACT ``` -The modified version used in **DeFinery** relies on our symbolic engine, the binary for which is available [for download](https://drive.google.com/file/d/1eDVyjNiSIqzFPpMXj0bTFRKAxTHkzsVY/view), and assumes that semantic analysis results are available in the `/experiments/CONTRACT_NAME` folder. +The modified version used in **DeFinery** relies on our symbolic engine, the binary for which is available in this repository, and assumes that semantic analysis results are available in the `./experiments/CONTRACT_NAME` folder. Original SCRepair Publication === diff --git a/build.sh b/build.sh new file mode 100644 index 0000000..b8e3f17 --- /dev/null +++ b/build.sh @@ -0,0 +1,51 @@ +apt update && apt upgrade -y && apt install -y build-essential libboost-all-dev cmake curl zip unzip tar # python3.7 git + +git clone https://github.com/Microsoft/vcpkg.git &&\ + cd vcpkg &&\ + ./bootstrap-vcpkg.sh &&\ + ./vcpkg integrate install &&\ + ./vcpkg install jsoncpp + +cd .. + + mkdir -p temp && cd /temp &&\ + git clone https://github.com/Z3Prover/z3.git &&\ + cd z3 && \ + git checkout z3-4.8.13 &&\ + python scripts/mk_make.py &&\ + cd build &&\ + make &&\ + make install + +cd ../../.. + + +git clone https://github.com/polinatolmach/DeFinery.git +cd DeFinery + +RUN unzip definery-see.zip +RUN chmod +x ./definery-see + +curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.1/install.sh | bash &&\ + export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")" &&\ + [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" &&\ + nvm install 14 &&\ + nvm use 14 + +export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")" &&\ + [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" &&\ + cd SCRepair/sm &&\ + npm install && npm run-script build + +# curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py &&\ +# python3.7 ./get-pip.py &&\ +# rm get-pip.py + +cd .. && python3.7 setup.py install + +pip install attrs charset_normalizer logbook deap docker + +mkdir contracts && mkdir experiments +cd .. +cp -r contracts/eval/* /SCRepair/contracts/ +cp definery-see SCRepair/ \ No newline at end of file