diff --git a/.gitignore b/.gitignore index 8ae2b229..0e253ae4 100644 --- a/.gitignore +++ b/.gitignore @@ -7,3 +7,4 @@ __pycache__ *~ package app/data/build_tag.txt +build diff --git a/app/data/compose/docker-compose-fixturenet-lotus.yml b/app/data/compose/docker-compose-fixturenet-lotus.yml new file mode 100644 index 00000000..d4e72b79 --- /dev/null +++ b/app/data/compose/docker-compose-fixturenet-lotus.yml @@ -0,0 +1,68 @@ +version: "3.8" +services: + + lotus-miner: + hostname: lotus-miner + env_file: + - ../config/fixturenet-lotus/lotus-env.env + image: cerc/lotus:local + volumes: + - ../config/fixturenet-lotus/setup-miner.sh:/docker-entrypoint-scripts.d/setup-miner.sh + - ../config/fixturenet-lotus/genesis/devgen.car:/devgen.car + - $HOME/stack-orchestrator/app/data/config/fixturenet-lotus/genesis/.genesis-sectors:/root/.genesis-sectors + - lotus-shared:/root/.lotus-shared + healthcheck: +# test: ["CMD-SHELL", "grep 'started ChainNotify channel' /var/log/lotus.log"] +# test: ["CMD-SHELL", "[ -f /root/.lotus-shared/miner.addr ]"] + test: ["CMD-SHELL", "[ -d /root/.lotus-miner-local-net ]"] + interval: 10s + timeout: 10s + retries: 10 + start_period: 60s + entrypoint: ["sh", "/docker-entrypoint-scripts.d/setup-miner.sh"] + ports: + - "1234" + - "2345" + - "3456" + - "1777" + + lotus-node-1: + hostname: lotus-node-1 + env_file: + - ../config/fixturenet-lotus/lotus-env.env + image: cerc/lotus:local + volumes: + - ../config/fixturenet-lotus/setup-node.sh:/docker-entrypoint-scripts.d/setup-node.sh + - ../config/fixturenet-lotus/genesis/devgen.car:/devgen.car + - lotus-shared:/root/.lotus-shared + depends_on: + lotus-miner: + condition: service_healthy + entrypoint: ["sh", "/docker-entrypoint-scripts.d/setup-node.sh"] + ports: + - "1234" + - "2345" + - "3456" + - "1777" + + lotus-node-2: + hostname: lotus-node-2 + env_file: + - ../config/fixturenet-lotus/lotus-env.env + image: cerc/lotus:local + volumes: + - ../config/fixturenet-lotus/setup-node.sh:/docker-entrypoint-scripts.d/setup-node.sh + - ../config/fixturenet-lotus/genesis/devgen.car:/devgen.car + - lotus-shared:/root/.lotus-shared + depends_on: + lotus-miner: + condition: service_healthy + entrypoint: ["sh", "/docker-entrypoint-scripts.d/setup-node.sh"] + ports: + - "1234" + - "2345" + - "3456" + - "1777" + +volumes: + lotus-shared: \ No newline at end of file diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/p_aux b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/p_aux new file mode 100644 index 00000000..81030cb4 --- /dev/null +++ b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/p_aux @@ -0,0 +1 @@ +}+V{iй\kq  ?Af~쩙Ltbyqč?aӚJ \ No newline at end of file diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/sc-02-data-tree-r-last.dat b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/sc-02-data-tree-r-last.dat new file mode 100644 index 00000000..5af05cae --- /dev/null +++ b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/sc-02-data-tree-r-last.dat @@ -0,0 +1 @@ +f~쩙Ltbyqč?aӚJ \ No newline at end of file diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/t_aux b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/t_aux new file mode 100644 index 00000000..09302363 Binary files /dev/null and b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-0/t_aux differ diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/p_aux b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/p_aux new file mode 100644 index 00000000..5ed0bcb8 Binary files /dev/null and b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/p_aux differ diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/sc-02-data-tree-r-last.dat b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/sc-02-data-tree-r-last.dat new file mode 100644 index 00000000..6165cf10 Binary files /dev/null and b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/sc-02-data-tree-r-last.dat differ diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/t_aux b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/t_aux new file mode 100644 index 00000000..1a9f9afc Binary files /dev/null and b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/cache/s-t01000-1/t_aux differ diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/pre-seal-t01000.json b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/pre-seal-t01000.json new file mode 100644 index 00000000..3a05d4b1 --- /dev/null +++ b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/pre-seal-t01000.json @@ -0,0 +1,71 @@ +{ + "t01000": { + "ID": "t01000", + "Owner": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q", + "Worker": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q", + "PeerId": "12D3KooWG5q6pWJVdPBhDBv9AjWVbUh4xxTAZ7xvgZSjczWuD2Z9", + "MarketBalance": "0", + "PowerBalance": "0", + "SectorSize": 2048, + "Sectors": [ + { + "CommR": { + "/": "bagboea4b5abcboxypcewlkmrat2myu4vthk3ii2pcomak7nhqmdbb6sxlolp2wdf" + }, + "CommD": { + "/": "baga6ea4seaqn3jfixthmdgksv4vhfeuyvr6upw6tvaqbmzmsyxnzosm4pwgnmlq" + }, + "SectorID": 0, + "Deal": { + "PieceCID": { + "/": "baga6ea4seaqn3jfixthmdgksv4vhfeuyvr6upw6tvaqbmzmsyxnzosm4pwgnmlq" + }, + "PieceSize": 2048, + "VerifiedDeal": false, + "Client": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q", + "Provider": "t01000", + "Label": "0", + "StartEpoch": 0, + "EndEpoch": 9001, + "StoragePricePerEpoch": "0", + "ProviderCollateral": "0", + "ClientCollateral": "0" + }, + "DealClientKey": { + "Type": "bls", + "PrivateKey": "tFvSRiSg2G3Ssgg0PSYy23XyjaIMXpsmdyG2B7UFLT4=" + }, + "ProofType": 5 + }, + { + "CommR": { + "/": "bagboea4b5abcb6krzypqcczhcnbeyjcqkeo6omfergm336o3kitugh3jgjog2yqq" + }, + "CommD": { + "/": "baga6ea4seaqhondpb2373hjasjplxvbjzi5n5mm4fbbhjxp5ptnbq4cibapkeii" + }, + "SectorID": 1, + "Deal": { + "PieceCID": { + "/": "baga6ea4seaqhondpb2373hjasjplxvbjzi5n5mm4fbbhjxp5ptnbq4cibapkeii" + }, + "PieceSize": 2048, + "VerifiedDeal": false, + "Client": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q", + "Provider": "t01000", + "Label": "1", + "StartEpoch": 0, + "EndEpoch": 9001, + "StoragePricePerEpoch": "0", + "ProviderCollateral": "0", + "ClientCollateral": "0" + }, + "DealClientKey": { + "Type": "bls", + "PrivateKey": "tFvSRiSg2G3Ssgg0PSYy23XyjaIMXpsmdyG2B7UFLT4=" + }, + "ProofType": 5 + } + ] + } +} \ No newline at end of file diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/pre-seal-t01000.key b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/pre-seal-t01000.key new file mode 100644 index 00000000..53e58628 --- /dev/null +++ b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/pre-seal-t01000.key @@ -0,0 +1 @@ +7b2254797065223a22626c73222c22507269766174654b6579223a227446765352695367324733537367673050535979323358796a61494d5870736d64794732423755464c54343d227d \ No newline at end of file diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sealed/s-t01000-0 b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sealed/s-t01000-0 new file mode 100644 index 00000000..56a0f872 Binary files /dev/null and b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sealed/s-t01000-0 differ diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sealed/s-t01000-1 b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sealed/s-t01000-1 new file mode 100644 index 00000000..dc3afe0f Binary files /dev/null and b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sealed/s-t01000-1 differ diff --git a/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sectorstore.json b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sectorstore.json new file mode 100644 index 00000000..a49be73f --- /dev/null +++ b/app/data/config/fixturenet-lotus/genesis/.genesis-sectors/sectorstore.json @@ -0,0 +1,11 @@ +{ + "ID": "f355523e-69d0-4984-bd0e-9588487c6231", + "Weight": 0, + "CanSeal": false, + "CanStore": false, + "MaxStorage": 0, + "Groups": null, + "AllowTo": null, + "AllowTypes": null, + "DenyTypes": null +} \ No newline at end of file diff --git a/app/data/config/fixturenet-lotus/genesis/devgen.car b/app/data/config/fixturenet-lotus/genesis/devgen.car new file mode 100644 index 00000000..a22eaed4 Binary files /dev/null and b/app/data/config/fixturenet-lotus/genesis/devgen.car differ diff --git a/app/data/config/fixturenet-lotus/genesis/localnet.json b/app/data/config/fixturenet-lotus/genesis/localnet.json new file mode 100644 index 00000000..06d3123e --- /dev/null +++ b/app/data/config/fixturenet-lotus/genesis/localnet.json @@ -0,0 +1,108 @@ +{ + "NetworkVersion": 18, + "Accounts": [ + { + "Type": "account", + "Balance": "50000000000000000000000000", + "Meta": { + "Owner": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q" + } + } + ], + "Miners": [ + { + "ID": "t01000", + "Owner": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q", + "Worker": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q", + "PeerId": "12D3KooWG5q6pWJVdPBhDBv9AjWVbUh4xxTAZ7xvgZSjczWuD2Z9", + "MarketBalance": "0", + "PowerBalance": "0", + "SectorSize": 2048, + "Sectors": [ + { + "CommR": { + "/": "bagboea4b5abcboxypcewlkmrat2myu4vthk3ii2pcomak7nhqmdbb6sxlolp2wdf" + }, + "CommD": { + "/": "baga6ea4seaqn3jfixthmdgksv4vhfeuyvr6upw6tvaqbmzmsyxnzosm4pwgnmlq" + }, + "SectorID": 0, + "Deal": { + "PieceCID": { + "/": "baga6ea4seaqn3jfixthmdgksv4vhfeuyvr6upw6tvaqbmzmsyxnzosm4pwgnmlq" + }, + "PieceSize": 2048, + "VerifiedDeal": false, + "Client": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q", + "Provider": "t01000", + "Label": "0", + "StartEpoch": 0, + "EndEpoch": 9001, + "StoragePricePerEpoch": "0", + "ProviderCollateral": "0", + "ClientCollateral": "0" + }, + "DealClientKey": { + "Type": "bls", + "PrivateKey": "tFvSRiSg2G3Ssgg0PSYy23XyjaIMXpsmdyG2B7UFLT4=" + }, + "ProofType": 5 + }, + { + "CommR": { + "/": "bagboea4b5abcb6krzypqcczhcnbeyjcqkeo6omfergm336o3kitugh3jgjog2yqq" + }, + "CommD": { + "/": "baga6ea4seaqhondpb2373hjasjplxvbjzi5n5mm4fbbhjxp5ptnbq4cibapkeii" + }, + "SectorID": 1, + "Deal": { + "PieceCID": { + "/": "baga6ea4seaqhondpb2373hjasjplxvbjzi5n5mm4fbbhjxp5ptnbq4cibapkeii" + }, + "PieceSize": 2048, + "VerifiedDeal": false, + "Client": "t3spusn5ia57qezc3fwpe3n2lhb4y4xt67xoflqbqy2muliparw2uktevletuv7gl4qakjpafgcl7jk2s2er3q", + "Provider": "t01000", + "Label": "1", + "StartEpoch": 0, + "EndEpoch": 9001, + "StoragePricePerEpoch": "0", + "ProviderCollateral": "0", + "ClientCollateral": "0" + }, + "DealClientKey": { + "Type": "bls", + "PrivateKey": "tFvSRiSg2G3Ssgg0PSYy23XyjaIMXpsmdyG2B7UFLT4=" + }, + "ProofType": 5 + } + ] + } + ], + "NetworkName": "localnet-6d52dae5-ff29-4bac-a45d-f84e6c07564c", + "VerifregRootKey": { + "Type": "multisig", + "Balance": "0", + "Meta": { + "Signers": [ + "t1ceb34gnsc6qk5dt6n7xg6ycwzasjhbxm3iylkiy" + ], + "Threshold": 1, + "VestingDuration": 0, + "VestingStart": 0 + } + }, + "RemainderAccount": { + "Type": "multisig", + "Balance": "0", + "Meta": { + "Signers": [ + "t1ceb34gnsc6qk5dt6n7xg6ycwzasjhbxm3iylkiy" + ], + "Threshold": 1, + "VestingDuration": 0, + "VestingStart": 0 + } + } +} \ No newline at end of file diff --git a/app/data/config/fixturenet-lotus/lotus-env.env b/app/data/config/fixturenet-lotus/lotus-env.env new file mode 100644 index 00000000..582b8944 --- /dev/null +++ b/app/data/config/fixturenet-lotus/lotus-env.env @@ -0,0 +1,5 @@ +LOTUS_PATH=~/.lotus-local-net +LOTUS_MINER_PATH=~/.lotus-miner-local-net +LOTUS_SKIP_GENESIS_CHECK=_yes_ +CGO_CFLAGS_ALLOW="-D__BLST_PORTABLE__" +CGO_CFLAGS="-D__BLST_PORTABLE__" diff --git a/app/data/config/fixturenet-lotus/setup-miner.sh b/app/data/config/fixturenet-lotus/setup-miner.sh new file mode 100644 index 00000000..1b818de6 --- /dev/null +++ b/app/data/config/fixturenet-lotus/setup-miner.sh @@ -0,0 +1,39 @@ +#!/bin/bash + +lotus --version + +# # remove old bootnode peer info if present +# [ -f /root/.lotus-shared/miner.addr ] && rm /root/.lotus-shared/miner.addr + +##TODO: generate genesis files inside container instead of bundling in config dir +##something like commands below should work, other scripts/compose will have to be updated to corresponding directories +# lotus fetch-params 2048 +# lotus-seed pre-seal --sector-size 2KiB --num-sectors 2 +# lotus-seed genesis new localnet.json +# lotus-seed genesis add-miner localnet.json ~/.genesis-sectors/pre-seal-t01000.json + + +# start daemon +nohup lotus daemon --genesis=/devgen.car --profile=bootstrapper --bootstrap=false > /var/log/lotus.log 2>&1 & + +# Loop until the daemon is started +echo "Waiting for daemon to start..." +while ! grep -q "started ChainNotify channel" /var/log/lotus.log ; do + sleep 5 +done +echo "Daemon started." + +# publish bootnode peer info to shared volume +lotus net listen | awk 'NR==1{print}' > /root/.lotus-shared/miner.addr + +# if miner not already initialized +if [ ! -d /root/.lotus-miner-local-net ]; then + # initialize miner + lotus wallet import --as-default ~/.genesis-sectors/pre-seal-t01000.key + lotus-miner init --genesis-miner --actor=t01000 --sector-size=2KiB --pre-sealed-sectors=~/.genesis-sectors --pre-sealed-metadata=~/.genesis-sectors/pre-seal-t01000.json --nosync +fi + +# start miner +nohup lotus-miner run --nosync & + +tail -f /dev/null diff --git a/app/data/config/fixturenet-lotus/setup-node.sh b/app/data/config/fixturenet-lotus/setup-node.sh new file mode 100644 index 00000000..0bcd4717 --- /dev/null +++ b/app/data/config/fixturenet-lotus/setup-node.sh @@ -0,0 +1,24 @@ +#!/bin/bash + +lotus --version + +##TODO: paths can use values from lotus-env.env file + +# if not already initialized +if [ ! -f /root/.lotus-local-net/config.toml ]; then + # init node config + mkdir $HOME/.lotus-local-net + lotus config default > $HOME/.lotus-local-net/config.toml + + # add bootstrap peer info if available + if [ -f /root/.lotus-shared/miner.addr ]; then + MINER_ADDR=\"$(cat /root/.lotus-shared/miner.addr)\" + # add bootstrap peer id to config file + sed -i "/^\[Libp2p\]/a \ \ BootstrapPeers = [$MINER_ADDR]" $HOME/.lotus-local-net/config.toml + else + echo "Bootstrap peer info not found, unable to configure. Manual peering will be required." + fi +fi + +# start node +lotus daemon --genesis=/devgen.car diff --git a/app/data/container-build/cerc-lotus/Dockerfile b/app/data/container-build/cerc-lotus/Dockerfile new file mode 100644 index 00000000..963de704 --- /dev/null +++ b/app/data/container-build/cerc-lotus/Dockerfile @@ -0,0 +1,138 @@ +##################################### +FROM golang:1.19.7-buster AS lotus-builder +MAINTAINER Lotus Development Team + +RUN apt-get update && apt-get install -y ca-certificates build-essential clang ocl-icd-opencl-dev ocl-icd-libopencl1 jq libhwloc-dev + +ENV XDG_CACHE_HOME="/tmp" + +### taken from https://github.com/rust-lang/docker-rust/blob/master/1.63.0/buster/Dockerfile +ENV RUSTUP_HOME=/usr/local/rustup \ + CARGO_HOME=/usr/local/cargo \ + PATH=/usr/local/cargo/bin:$PATH \ + RUST_VERSION=1.63.0 + +RUN set -eux; \ + dpkgArch="$(dpkg --print-architecture)"; \ + case "${dpkgArch##*-}" in \ + amd64) rustArch='x86_64-unknown-linux-gnu'; rustupSha256='5cc9ffd1026e82e7fb2eec2121ad71f4b0f044e88bca39207b3f6b769aaa799c' ;; \ + arm64) rustArch='aarch64-unknown-linux-gnu'; rustupSha256='e189948e396d47254103a49c987e7fb0e5dd8e34b200aa4481ecc4b8e41fb929' ;; \ + *) echo >&2 "unsupported architecture: ${dpkgArch}"; exit 1 ;; \ + esac; \ + url="https://static.rust-lang.org/rustup/archive/1.25.1/${rustArch}/rustup-init"; \ + wget "$url"; \ + echo "${rustupSha256} *rustup-init" | sha256sum -c -; \ + chmod +x rustup-init; \ + ./rustup-init -y --no-modify-path --profile minimal --default-toolchain $RUST_VERSION --default-host ${rustArch}; \ + rm rustup-init; \ + chmod -R a+w $RUSTUP_HOME $CARGO_HOME; \ + rustup --version; \ + cargo --version; \ + rustc --version; + +COPY ./ /opt/filecoin +WORKDIR /opt/filecoin + +#RUN scripts/docker-git-state-check.sh + +### make configurable filecoin-ffi build +ARG FFI_BUILD_FROM_SOURCE=0 +ENV FFI_BUILD_FROM_SOURCE=${FFI_BUILD_FROM_SOURCE} + +RUN make clean deps + +ARG RUSTFLAGS="" +ARG GOFLAGS="" + +#RUN make buildall +RUN make 2k + +##################################### +FROM ubuntu:20.04 AS lotus-base +MAINTAINER Lotus Development Team + +# Base resources +COPY --from=lotus-builder /etc/ssl/certs /etc/ssl/certs +COPY --from=lotus-builder /lib/*/libdl.so.2 /lib/ +COPY --from=lotus-builder /lib/*/librt.so.1 /lib/ +COPY --from=lotus-builder /lib/*/libgcc_s.so.1 /lib/ +COPY --from=lotus-builder /lib/*/libutil.so.1 /lib/ +COPY --from=lotus-builder /usr/lib/*/libltdl.so.7 /lib/ +COPY --from=lotus-builder /usr/lib/*/libnuma.so.1 /lib/ +COPY --from=lotus-builder /usr/lib/*/libhwloc.so.5 /lib/ +COPY --from=lotus-builder /usr/lib/*/libOpenCL.so.1 /lib/ + +RUN useradd -r -u 532 -U fc \ + && mkdir -p /etc/OpenCL/vendors \ + && echo "libnvidia-opencl.so.1" > /etc/OpenCL/vendors/nvidia.icd + +##################################### +FROM lotus-base AS lotus +MAINTAINER Lotus Development Team + +COPY --from=lotus-builder /opt/filecoin/lotus /usr/local/bin/ +COPY --from=lotus-builder /opt/filecoin/lotus-shed /usr/local/bin/ +#COPY scripts/docker-lotus-entrypoint.sh / +#COPY myscripts/setup-node.sh /docker-entrypoint-scripts.d/setup-node.sh + +ARG DOCKER_LOTUS_IMPORT_SNAPSHOT https://snapshots.mainnet.filops.net/minimal/latest +ENV DOCKER_LOTUS_IMPORT_SNAPSHOT ${DOCKER_LOTUS_IMPORT_SNAPSHOT} +ENV FILECOIN_PARAMETER_CACHE /var/tmp/filecoin-proof-parameters +ENV LOTUS_PATH /var/lib/lotus +ENV DOCKER_LOTUS_IMPORT_WALLET "" + +RUN mkdir /var/lib/lotus /var/tmp/filecoin-proof-parameters +RUN chown fc: /var/lib/lotus /var/tmp/filecoin-proof-parameters + +VOLUME /var/lib/lotus +VOLUME /var/tmp/filecoin-proof-parameters + +USER fc + +EXPOSE 1234 + +ENTRYPOINT ["/docker-lotus-entrypoint.sh"] + +CMD ["-help"] + +##################################### +FROM lotus-base AS lotus-all-in-one + +ENV FILECOIN_PARAMETER_CACHE /var/tmp/filecoin-proof-parameters +ENV LOTUS_MINER_PATH /var/lib/lotus-miner +ENV LOTUS_PATH /var/lib/lotus +ENV LOTUS_WORKER_PATH /var/lib/lotus-worker +ENV WALLET_PATH /var/lib/lotus-wallet + +COPY --from=lotus-builder /opt/filecoin/lotus /usr/local/bin/ +COPY --from=lotus-builder /opt/filecoin/lotus-seed /usr/local/bin/ +COPY --from=lotus-builder /opt/filecoin/lotus-shed /usr/local/bin/ +#COPY --from=lotus-builder /opt/filecoin/lotus-wallet /usr/local/bin/ +#COPY --from=lotus-builder /opt/filecoin/lotus-gateway /usr/local/bin/ +COPY --from=lotus-builder /opt/filecoin/lotus-miner /usr/local/bin/ +COPY --from=lotus-builder /opt/filecoin/lotus-worker /usr/local/bin/ +#COPY --from=lotus-builder /opt/filecoin/lotus-stats /usr/local/bin/ +#COPY --from=lotus-builder /opt/filecoin/lotus-fountain /usr/local/bin/ + +RUN mkdir /var/tmp/filecoin-proof-parameters +RUN mkdir /var/lib/lotus +RUN mkdir /var/lib/lotus-miner +RUN mkdir /var/lib/lotus-worker +RUN mkdir /var/lib/lotus-wallet +RUN chown fc: /var/tmp/filecoin-proof-parameters +RUN chown fc: /var/lib/lotus +RUN chown fc: /var/lib/lotus-miner +RUN chown fc: /var/lib/lotus-worker +RUN chown fc: /var/lib/lotus-wallet + + +#VOLUME /var/tmp/filecoin-proof-parameters +#VOLUME /var/lib/lotus +#VOLUME /var/lib/lotus-miner +#VOLUME /var/lib/lotus-worker +#VOLUME /var/lib/lotus-wallet + +EXPOSE 1234 +EXPOSE 2345 +EXPOSE 3456 +EXPOSE 1777 diff --git a/app/data/container-build/cerc-lotus/build.sh b/app/data/container-build/cerc-lotus/build.sh new file mode 100755 index 00000000..10bbf42c --- /dev/null +++ b/app/data/container-build/cerc-lotus/build.sh @@ -0,0 +1,12 @@ +#!/usr/bin/env bash +# Build cerc/lotus +source ${CERC_CONTAINER_BASE_DIR}/build-base.sh +SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ) + +# Per lotus docs, 'releases' branch always contains latest stable release +git -C ${CERC_REPO_BASE_DIR}/lotus checkout releases + +# Replace repo's Dockerfile with modified one +cp ${SCRIPT_DIR}/Dockerfile ${CERC_REPO_BASE_DIR}/lotus/Dockerfile + +docker build -t cerc/lotus:local ${build_command_args} ${CERC_REPO_BASE_DIR}/lotus diff --git a/app/data/container-image-list.txt b/app/data/container-image-list.txt index ab0a87b5..2d8e7621 100644 --- a/app/data/container-image-list.txt +++ b/app/data/container-image-list.txt @@ -40,3 +40,4 @@ cerc/pocket cerc/watcher-azimuth cerc/ipld-eth-state-snapshot cerc/watcher-gelato +cerc/lotus diff --git a/app/data/pod-list.txt b/app/data/pod-list.txt index 6c98c76c..79d66e87 100644 --- a/app/data/pod-list.txt +++ b/app/data/pod-list.txt @@ -27,3 +27,4 @@ fixturenet-optimism fixturenet-pocket watcher-azimuth watcher-gelato +fixturenet-lotus diff --git a/app/data/repository-list.txt b/app/data/repository-list.txt index 4b257813..84d11b1a 100644 --- a/app/data/repository-list.txt +++ b/app/data/repository-list.txt @@ -32,3 +32,4 @@ pokt-network/pocket-core-deployments cerc-io/azimuth-watcher-ts cerc-io/ipld-eth-state-snapshot cerc-io/gelato-watcher-ts +filecoin-project/lotus diff --git a/app/data/stacks/fixturenet-lotus/README.md b/app/data/stacks/fixturenet-lotus/README.md new file mode 100644 index 00000000..28df8264 --- /dev/null +++ b/app/data/stacks/fixturenet-lotus/README.md @@ -0,0 +1,28 @@ +# Lotus Fixturenet + +Instructions for deploying a local Lotus (Filecoin) chain for development and testing purposes using laconic-stack-orchestrator. + +## 1. Clone required repositories +``` +$ laconic-so --stack fixturenet-lotus setup-repositories +``` +## 2. Build the stack's packages and containers +``` +$ laconic-so --stack fixturenet-lotus build-containers +``` +## 3. Deploy the stack +``` +$ laconic-so --stack fixturenet-lotus deploy up +``` +Correct operation should be verified by checking the container logs with: +``` +$ laconic-so --stack fixturenet-lotus deploy logs lotus-miner +$ laconic-so --stack fixturenet-lotus deploy logs lotus-node-1 +$ laconic-so --stack fixturenet-lotus deploy logs lotus-node-2 +``` +or by checking the chain status on each node: +``` +$ laconic-so --stack fixturenet-lotus deploy exec lotus-miner "lotus status" +$ laconic-so --stack fixturenet-lotus deploy exec lotus-node-1 "lotus status" +$ laconic-so --stack fixturenet-lotus deploy exec lotus-node-2 "lotus status" +``` \ No newline at end of file diff --git a/app/data/stacks/fixturenet-lotus/stack.yml b/app/data/stacks/fixturenet-lotus/stack.yml new file mode 100644 index 00000000..35617c4b --- /dev/null +++ b/app/data/stacks/fixturenet-lotus/stack.yml @@ -0,0 +1,9 @@ +version: "1.0" +name: fixturenet-lotus +description: "A lotus fixturenet" +repos: + - filecoin-project/lotus +containers: + - cerc/lotus +pods: + - fixturenet-lotus