forked from dedis/d-voting
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: dockerized deployment, including helper script to set up/tear d…
…own Docker development environment
- Loading branch information
1 parent
739a78b
commit 4b61aa4
Showing
5 changed files
with
201 additions
and
73 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
# This is an example .env file with default passwords and private keys. | ||
# Do not use this in production or with any public-facing ports! | ||
BACKEND_HOST=backend # name of the 'backend' container | ||
BACKEND_PORT=5000 # port of the 'backend' container | ||
COMPOSE_FILE=./docker-compose/docker-compose.yml # Docker Compose configuration file to use | ||
DATABASE_HOST=db # name of the PostgreSQL container | ||
DATABASE_PASSWORD=Ohw0phoa # choose any PostgreSQL password | ||
DATABASE_PORT=5432 # port of the PostgreSQL container | ||
DATABASE_USERNAME=dvoting | ||
DB_PATH=dvoting # LMDB database path | ||
DELA_PROXY_URL=http://172.19.44.254:8080 # IP and port of one of the DELA containers | ||
FRONT_END_URL=http://127.0.0.1:3000 # the automated frontend tests expect this value do not change it | ||
NODEPORT=2000 # DELA node port | ||
# For public-facing services and production, this key needs to be changed! | ||
PRIVATE_KEY=6aadf480d068ac896330b726802abd0da2a5f3824f791fe8dbd4cd555e80b809 | ||
PROXYPORT=8080 # DELA proxy port | ||
PUBLIC_KEY=3e5fcaed4c5d79a8eccceeb087ee0a13b8f91d917ed62017a9cd28e13b228389 | ||
REACT_APP_DEV_LOGIN=true # debugging admin login /!\ disable in production /!\ | ||
REACT_APP_RANDOMIZE_VOTE_ID=true # randomize voter ID for debugging /!\ disable in production /!\ | ||
REACT_APP_SCIPER_ADMIN=123456 # debugging admin ID /!\ disable in production /!\ | ||
SESSION_SECRET=kaibaaF9 # choose any secret |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,17 +1,19 @@ | ||
FROM golang:1.20.6-bookworm AS base | ||
RUN apt-get update && apt-get install git | ||
# make sure we're using the same head as d-voting | ||
RUN git clone https://github.com/c4dt/dela.git | ||
WORKDIR /go/dela/cli/crypto | ||
RUN go install | ||
WORKDIR /go/d-voting | ||
COPY go.mod . | ||
COPY go.sum . | ||
RUN go mod download | ||
COPY . . | ||
|
||
FROM base AS build | ||
COPY --from=base /go/dela . | ||
COPY --from=base /go/d-voting . | ||
ENV GOCACHE=/root/.cache/go-build | ||
WORKDIR /go/d-voting/cli/dvoting | ||
RUN go build | ||
ENV PATH=/go/dela/cli/crypto:/go/d-voting/cli/dvoting:${PATH} | ||
RUN --mount=type=cache,target="/root/.cache/go-build" go install | ||
# make sure we're using the same head as d-voting | ||
RUN --mount=type=cache,target="/root/.cache/go-build" cd $( go list -f '{{.Dir}}' go.dedis.ch/dela )/cli/crypto && go install | ||
|
||
FROM golang:1.20.6-bookworm AS build | ||
WORKDIR /usr/local/bin | ||
COPY --from=base /go/bin/crypto . | ||
COPY --from=base /go/bin/dvoting . | ||
ENTRYPOINT ["/bin/bash", "-c", "dvoting --config /data/node start --postinstall --proxyaddr :$PROXYPORT --proxykey $PROXYKEY --listen tcp://0.0.0.0:2000 --public $PUBLIC_URL --routing tree --noTLS"] | ||
CMD [] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,128 @@ | ||
#!/bin/bash -e | ||
|
||
# The script must be called from the root of the github tree, else it returns an error. | ||
# This script currently only works on Linux due to differences in network management on Windows/macOS. | ||
|
||
if [[ $(git rev-parse --show-toplevel) != $(pwd) ]]; then | ||
echo "ERROR: This script must be started from the root of the git repo"; | ||
exit 1; | ||
fi | ||
|
||
if [[ ! -f .env ]]; then | ||
cp .env.example .env | ||
fi | ||
|
||
source ./.env; | ||
export COMPOSE_FILE=${COMPOSE_FILE:-./docker-compose/docker-compose.yml}; | ||
|
||
|
||
function setup() { | ||
docker compose build; | ||
docker compose up -d; | ||
} | ||
|
||
function teardown() { | ||
rm -f cookies.txt; | ||
docker compose down -v; | ||
docker image rm ghcr.io/c4dt/d-voting-frontend:latest ghcr.io/c4dt/d-voting-backend:latest ghcr.io/c4dt/d-voting-dela:latest; | ||
} | ||
|
||
function init_dela() { | ||
LEADER=dela-worker-0; | ||
echo "$LEADER is the initial leader node"; | ||
|
||
echo "add nodes to the chain"; | ||
MEMBERS="" | ||
for node in $(seq 0 3); do | ||
MEMBERS="$MEMBERS --member $(docker compose exec dela-worker-$node /bin/bash -c 'LLVL=error dvoting --config /data/node ordering export')"; | ||
done | ||
docker compose exec "$LEADER" dvoting --config /data/node ordering setup $MEMBERS; | ||
|
||
echo "authorize signers to handle access contract on each node"; | ||
for signer in $(seq 0 3); do | ||
IDENTITY=$(docker compose exec "dela-worker-$signer" crypto bls signer read --path /data/node/private.key --format BASE64_PUBKEY); | ||
for node in $(seq 0 3); do | ||
docker compose exec "dela-worker-$node" dvoting --config /data/node access add --identity "$IDENTITY"; | ||
done | ||
done | ||
|
||
echo "update the access contract"; | ||
for node in $(seq 0 3); do | ||
IDENTITY=$(docker compose exec dela-worker-"$node" crypto bls signer read --path /data/node/private.key --format BASE64_PUBKEY); | ||
docker compose exec "$LEADER" dvoting --config /data/node pool add\ | ||
--key /data/node/private.key\ | ||
--args go.dedis.ch/dela.ContractArg\ | ||
--args go.dedis.ch/dela.Access\ | ||
--args access:grant_id\ | ||
--args 45564f54\ | ||
--args access:grant_contract\ | ||
--args go.dedis.ch/dela.Evoting \ | ||
--args access:grant_command\ | ||
--args all\ | ||
--args access:identity\ | ||
--args $IDENTITY\ | ||
--args access:command\ | ||
--args GRANT | ||
done | ||
} | ||
|
||
|
||
function local_admin() { | ||
echo "adding local user $REACT_APP_SCIPER_ADMIN to admins"; | ||
docker compose exec backend npx cli addAdmin --sciper "$REACT_APP_SCIPER_ADMIN"; | ||
docker compose exec backend npx cli addAdmin --sciper 987654; | ||
docker compose restart backend; | ||
} | ||
|
||
|
||
function local_login() { | ||
if ! [ -f cookies.txt ]; then | ||
echo "getting dummy login cookie"; | ||
curl -k "$FRONT_END_URL/api/get_dev_login/$REACT_APP_SCIPER_ADMIN" -c cookies.txt -o /dev/null -s; | ||
fi | ||
} | ||
|
||
function add_proxies() { | ||
|
||
echo "adding proxies"; | ||
|
||
for node in $(seq 0 3); do | ||
echo "adding proxy for node dela-worker-$node"; | ||
curl -sk "$FRONT_END_URL/api/proxies/" -X POST -H 'Content-Type: application/json' -b cookies.txt --data "{\"NodeAddr\":\"grpc://dela-worker-$node:$NODEPORT\",\"Proxy\":\"http://172.19.44.$((254 - node)):$PROXYPORT\"}"; | ||
done | ||
} | ||
|
||
case "$1" in | ||
|
||
setup) | ||
setup; | ||
;; | ||
|
||
init_dela) | ||
init_dela; | ||
;; | ||
|
||
teardown) | ||
teardown; | ||
exit | ||
;; | ||
|
||
local_admin) | ||
local_admin; | ||
;; | ||
|
||
add_proxies) | ||
local_login; | ||
add_proxies; | ||
;; | ||
|
||
*) | ||
setup; | ||
sleep 16; # give DELA nodes time to start up | ||
init_dela; | ||
local_admin; | ||
sleep 8; # give backend time to restart | ||
local_login; | ||
add_proxies; | ||
;; | ||
esac |