From cd00e1999255291ae02c071ae5bcc398f3e96104 Mon Sep 17 00:00:00 2001 From: jaensen <4954577+jaensen@users.noreply.github.com> Date: Fri, 17 Feb 2023 01:39:59 +0100 Subject: [PATCH 1/7] return decimal values instead of hex values for json-rpc transfer results --- src/server.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/server.rs b/src/server.rs index 5b894c2..a6408f4 100644 --- a/src/server.rs +++ b/src/server.rs @@ -162,13 +162,13 @@ fn compute_transfer( &(jsonrpc_result( request.id.clone(), json::object! { - flow: flow.to_string(), + flow: flow.to_decimal(), final: max_distance.is_none(), transfers: transfers.into_iter().map(|e| json::object! { from: e.from.to_checksummed_hex(), to: e.to.to_checksummed_hex(), token_owner: e.token.to_checksummed_hex(), - value: e.capacity.to_string() + value: e.capacity.to_decimal(), }).collect::>(), }, ) + "\r\n"), From b120a45d86740445514e4de585901da592729b7e Mon Sep 17 00:00:00 2001 From: JacqueGM Date: Tue, 21 Feb 2023 13:08:37 +0100 Subject: [PATCH 2/7] update json keys --- src/server.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/server.rs b/src/server.rs index a6408f4..ca01750 100644 --- a/src/server.rs +++ b/src/server.rs @@ -162,9 +162,9 @@ fn compute_transfer( &(jsonrpc_result( request.id.clone(), json::object! { - flow: flow.to_decimal(), + maxFlowValue: flow.to_decimal(), final: max_distance.is_none(), - transfers: transfers.into_iter().map(|e| json::object! { + transferSteps: transfers.into_iter().map(|e| json::object! { from: e.from.to_checksummed_hex(), to: e.to.to_checksummed_hex(), token_owner: e.token.to_checksummed_hex(), From 56c45423f029ef40555c5d3936608897635132a2 Mon Sep 17 00:00:00 2001 From: jaensen <4954577+jaensen@users.noreply.github.com> Date: Fri, 17 Feb 2023 01:39:59 +0100 Subject: [PATCH 3/7] return decimal values instead of hex values for json-rpc transfer results --- src/server.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/server.rs b/src/server.rs index 5b894c2..a6408f4 100644 --- a/src/server.rs +++ b/src/server.rs @@ -162,13 +162,13 @@ fn compute_transfer( &(jsonrpc_result( request.id.clone(), json::object! { - flow: flow.to_string(), + flow: flow.to_decimal(), final: max_distance.is_none(), transfers: transfers.into_iter().map(|e| json::object! { from: e.from.to_checksummed_hex(), to: e.to.to_checksummed_hex(), token_owner: e.token.to_checksummed_hex(), - value: e.capacity.to_string() + value: e.capacity.to_decimal(), }).collect::>(), }, ) + "\r\n"), From be53b77f88596d1fcb2798d9cc3099ad147f624e Mon Sep 17 00:00:00 2001 From: JacqueGM Date: Tue, 21 Feb 2023 13:08:37 +0100 Subject: [PATCH 4/7] update json keys --- src/server.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/server.rs b/src/server.rs index a6408f4..ca01750 100644 --- a/src/server.rs +++ b/src/server.rs @@ -162,9 +162,9 @@ fn compute_transfer( &(jsonrpc_result( request.id.clone(), json::object! { - flow: flow.to_decimal(), + maxFlowValue: flow.to_decimal(), final: max_distance.is_none(), - transfers: transfers.into_iter().map(|e| json::object! { + transferSteps: transfers.into_iter().map(|e| json::object! { from: e.from.to_checksummed_hex(), to: e.to.to_checksummed_hex(), token_owner: e.token.to_checksummed_hex(), From cadee86f6ab9b65dad80a73c81c5b60d7d929cb0 Mon Sep 17 00:00:00 2001 From: jaensen Date: Wed, 18 Jan 2023 02:24:56 +0100 Subject: [PATCH 5/7] add a dockerfile and github workflow to build it --- .github/workflows/build-and-push.yml | 88 ++++++++++++++++++++++++++++ .github/workflows/dev.yml | 17 ++++++ Dockerfile | 15 +++++ 3 files changed, 120 insertions(+) create mode 100644 .github/workflows/build-and-push.yml create mode 100644 .github/workflows/dev.yml create mode 100644 Dockerfile diff --git a/.github/workflows/build-and-push.yml b/.github/workflows/build-and-push.yml new file mode 100644 index 0000000..b5390bb --- /dev/null +++ b/.github/workflows/build-and-push.yml @@ -0,0 +1,88 @@ +name: Build and push image from ref + +on: + workflow_call: + inputs: + ref: + description: "A ref from this repository, CirclesUBI/pathfinder2" + required: true + type: string + image: + description: "The desired name of the image to build" + default: 'pathfinder2' + required: false + type: string + workflow_dispatch: + inputs: + ref: + description: "A ref from this repository, CirclesUBI/pathfinder2" + required: true + type: string + image: + description: "The desired name of the image to build" + default: 'pathfinder2' + required: false + type: string + +jobs: + + build-and-push-image: + + runs-on: ubuntu-latest + permissions: + contents: read + id-token: write + + steps: + + - + name: Checkout repository + uses: actions/checkout@v3 + with: + ref: ${{ inputs.ref }} + + - + name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + + - + name: Docker meta + id: meta + uses: docker/metadata-action@v4 + with: + images: | + ${{ vars.GC_REGISTRY }}/${{ vars.GC_PROJECT_ID }}/${{ inputs.image }} + labels: | + org.opencontainers.image.title=${{ inputs.image }} + org.opencontainers.image.vendor=CirclesUBI + tags: | + type=raw,value=latest,enable={{is_default_branch}} + type=semver,pattern={{version}} + {{ tag }} + {{ base_ref }} + {{ branch }} + type=sha,prefix={{branch}}- + {{ sha }} + + - + name: Authenticate to Google Cloud + id: auth + uses: google-github-actions/auth@v1 + with: + workload_identity_provider: "${{ vars.GC_WLI_PROVIDER }}" + service_account: "${{ vars.GC_WLI_SA }}" + token_format: 'access_token' + + - + name: Login to Container Registry + uses: docker/login-action@v2 + with: + registry: ${{ vars.GC_REGISTRY }} + username: 'oauth2accesstoken' + password: '${{ steps.auth.outputs.access_token }}' + + - name: Build and push Docker image + uses: docker/build-push-action@v3 + with: + push: true + tags: ${{ steps.meta.outputs.tags }} diff --git a/.github/workflows/dev.yml b/.github/workflows/dev.yml new file mode 100644 index 0000000..9d62173 --- /dev/null +++ b/.github/workflows/dev.yml @@ -0,0 +1,17 @@ +name: Build and push the dev image + +on: + push: + branches: [ feature/dockerfile ] + +jobs: + call-build-and-push: + name: Trigger container build and push + permissions: + contents: read + id-token: write + uses: ./.github/workflows/build-and-push.yml + with: + ref: "${{ github.ref }}" + image: "pathfinder2" + secrets: inherit diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..0ab8283 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,15 @@ +FROM rust:latest AS build + +WORKDIR /build +COPY . . + +RUN cargo install --path . +RUN cargo build --release + +FROM rust AS app + +WORKDIR /app +COPY --from=build /build/target/release . +RUN chmod +x ./server + +ENTRYPOINT ["./server"] From d90005285e9dd84f713d1ea78abfbc2af75b6e83 Mon Sep 17 00:00:00 2001 From: Jon Richter Date: Thu, 19 Jan 2023 00:41:16 +0100 Subject: [PATCH 6/7] ci : add Docker Hub and GitHub Packages registries --- .github/workflows/build-and-push.yml | 37 ++++++++++++++++++---------- .github/workflows/dev.yml | 4 +-- 2 files changed, 25 insertions(+), 16 deletions(-) diff --git a/.github/workflows/build-and-push.yml b/.github/workflows/build-and-push.yml index b5390bb..1143006 100644 --- a/.github/workflows/build-and-push.yml +++ b/.github/workflows/build-and-push.yml @@ -1,12 +1,8 @@ -name: Build and push image from ref +name: Build and push image on: workflow_call: inputs: - ref: - description: "A ref from this repository, CirclesUBI/pathfinder2" - required: true - type: string image: description: "The desired name of the image to build" default: 'pathfinder2' @@ -14,10 +10,6 @@ on: type: string workflow_dispatch: inputs: - ref: - description: "A ref from this repository, CirclesUBI/pathfinder2" - required: true - type: string image: description: "The desired name of the image to build" default: 'pathfinder2' @@ -32,14 +24,13 @@ jobs: permissions: contents: read id-token: write + packages: write steps: - name: Checkout repository uses: actions/checkout@v3 - with: - ref: ${{ inputs.ref }} - name: Set up Docker Buildx @@ -52,6 +43,8 @@ jobs: with: images: | ${{ vars.GC_REGISTRY }}/${{ vars.GC_PROJECT_ID }}/${{ inputs.image }} + docker.io/${{ vars.DH_ORGANIZATION }}/${{ inputs.image }} + ghcr.io/${{ github.repository_owner }}/${{ inputs.image }} labels: | org.opencontainers.image.title=${{ inputs.image }} org.opencontainers.image.vendor=CirclesUBI @@ -74,15 +67,33 @@ jobs: token_format: 'access_token' - - name: Login to Container Registry + name: Login to Google Cloud Container Registry uses: docker/login-action@v2 with: registry: ${{ vars.GC_REGISTRY }} username: 'oauth2accesstoken' password: '${{ steps.auth.outputs.access_token }}' - - name: Build and push Docker image + - + name: Login to Docker Hub Registry + uses: docker/login-action@v2 + with: + registry: docker.io + username: ${{ vars.DH_USERNAME }} + password: ${{ secrets.DH_TOKEN }} + + - + name: Login to GitHub Packages Registry + uses: docker/login-action@v2 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - + name: Build and push Container image uses: docker/build-push-action@v3 with: push: true tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} diff --git a/.github/workflows/dev.yml b/.github/workflows/dev.yml index 9d62173..d961675 100644 --- a/.github/workflows/dev.yml +++ b/.github/workflows/dev.yml @@ -10,8 +10,6 @@ jobs: permissions: contents: read id-token: write + packages: write uses: ./.github/workflows/build-and-push.yml - with: - ref: "${{ github.ref }}" - image: "pathfinder2" secrets: inherit From 21f74acc17fd8b791df9f3c09d6de4ba81299562 Mon Sep 17 00:00:00 2001 From: Jon Richter Date: Thu, 19 Jan 2023 00:49:06 +0100 Subject: [PATCH 7/7] upd(ci): downgrade buildkit Resolves errors upstream, see: - https://github.com/docker/build-push-action/issues/761#issuecomment-1383822381 - https://github.com/moby/buildkit/issues/3347#issuecomment-1381855209 --- .github/workflows/build-and-push.yml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.github/workflows/build-and-push.yml b/.github/workflows/build-and-push.yml index 1143006..fff9d39 100644 --- a/.github/workflows/build-and-push.yml +++ b/.github/workflows/build-and-push.yml @@ -35,6 +35,9 @@ jobs: - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 + with: + driver-opts: | + image=moby/buildkit:v0.10.6 - name: Docker meta