Skip to content

Commit

Permalink
Upgrade to Node 8.9.2 (#1251)
Browse files Browse the repository at this point in the history
chore: Upgrade to Ogmios 6.3.0, Node 8.9.2 and DbSsync 13.2.0.2

Backports changes done in `conway-era` branch:
- Upgraded Ogmios to 6.3 following migration guide [ADR-017](https://github.com/CardanoSolutions/ogmios/blob/master/architectural-decisions/accepted/017-api-version-6-major-rewrite.md) 
- Upgraded Node to 8.9.2 and DbSync to 13.2.0.2
- Enabled Peer2Peer topology support.
- DbSync based providers updated for schema compatibility with DbSync 13.2.0.2: DbSyncChainSyncProvider,
  DbSyncNetworkInfoProvider, DbSyncStakePoolProvider, 
- Added Ogmios NodeTxSubmitProvider.
- Modified Ogmios block structure mappers for Ogmios6 model.
- Updated Ogmios errors and handles for detailed error handling.
  • Loading branch information
mirceahasegan authored Jun 14, 2024
1 parent ddb7e72 commit 9c7e831
Show file tree
Hide file tree
Showing 188 changed files with 17,371 additions and 16,571 deletions.
9 changes: 9 additions & 0 deletions .github/workflows/std.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,11 @@ on:
type: boolean
required: true
default: false
deploy-dev-preprod-resync:
description: Deploy to dev-preprod-resync
type: boolean
required: true
default: false
deploy-staging-preprod:
description: Deploy to staging-preprod
type: boolean
Expand Down Expand Up @@ -104,6 +109,9 @@ jobs:
if [ "true" == ${{ inputs.deploy-dev-preprod || false }} ] ; then
echo '{"environment":"dev-preprod", "target":"dev-preprod@us-east-1@v2", "url": "https://dev-preprod.lw.iog.io/"}'
fi
if [ "true" == ${{ inputs.deploy-dev-preprod-resync || false }} ] ; then
echo '{"environment":"dev-preprod-resync", "target":"dev-preprod-resync@us-east-1@v2", "url": "https://dev-preprod-resync.lw.iog.io/"}'
fi
if [ "true" == ${{ inputs.deploy-staging-preprod || false }} ] ; then
echo '{"environment":"staging-preprod", "target":"staging-preprod@us-east-1@v2", "url": "https://staging-preprod.lw.iog.io/"}'
fi
Expand Down Expand Up @@ -218,6 +226,7 @@ jobs:
for target in \
"dev-preview@us-east-1" \
"dev-preprod@us-east-1@v2" \
"dev-preprod-resync@us-east-1@v2" \
"dev-mainnet@us-east-1" \
; do
git restore .kube
Expand Down
8 changes: 4 additions & 4 deletions compose/aarch64.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@

services:
cardano-db-sync:
image: ghcr.io/input-output-hk/ogmios-tracker/cardano-db-sync:${CARDANO_DB_SYNC_VERSION:-13.1.0.0}
image: ghcr.io/input-output-hk/ogmios-tracker/cardano-db-sync:${CARDANO_DB_SYNC_VERSION:-13.2.0.2}
cardano-node:
image: ghcr.io/input-output-hk/ogmios-tracker/cardano-node:${CARDANO_NODE_VERSION:-1.35.5}
image: ghcr.io/input-output-hk/ogmios-tracker/cardano-node:${CARDANO_NODE_VERSION:-8.9.2}
ogmios:
image: ghcr.io/input-output-hk/ogmios-tracker/ogmios:v${OGMIOS_VERSION:-5.6.0}
image: ghcr.io/input-output-hk/ogmios-tracker/ogmios:v${OGMIOS_VERSION:-6.3.0}
cardano-submit-api:
image: ghcr.io/input-output-hk/ogmios-tracker/cardano-submit-api:${CARDANO_NODE_VERSION:-1.35.5}
image: ghcr.io/input-output-hk/ogmios-tracker/cardano-submit-api:${CARDANO_NODE_VERSION:-8.9.2}
15 changes: 9 additions & 6 deletions compose/common.yml
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@ services:
depends_on:
ogmios:
condition: service_healthy
image: ghcr.io/intersectmbo/cardano-db-sync:${CARDANO_DB_SYNC_VERSION:-13.1.0.2}
image: ghcr.io/intersectmbo/cardano-db-sync:${CARDANO_DB_SYNC_VERSION:-13.2.0.2}
restart: on-failure
stop_signal: SIGINT
volumes:
Expand All @@ -122,7 +122,7 @@ services:
<<:
- *logging
- *with-postgres
image: ghcr.io/intersectmbo/cardano-smash-server:${CARDANO_DB_SYNC_VERSION:-13.1.0.2}
image: ghcr.io/intersectmbo/cardano-smash-server:${CARDANO_DB_SYNC_VERSION:-13.2.0.2}-docker
command: ['--config', '/config/cardano-db-sync/config.json']
environment:
POSTGRES_HOST: postgres
Expand All @@ -143,7 +143,7 @@ services:

cardano-node:
<<: *logging
image: public.ecr.aws/e8d0p1a5/cardano-node:${CARDANO_NODE_VERSION:-1.35.5}
image: ghcr.io/intersectmbo/cardano-node:${CARDANO_NODE_VERSION:-8.9.2}
command:
[
'run',
Expand All @@ -163,9 +163,12 @@ services:

ogmios:
<<: *logging
image: cardanosolutions/ogmios:v${OGMIOS_VERSION:-5.6.0}
image: cardanosolutions/ogmios:v${OGMIOS_VERSION:-6.3.0}
command:
['--host', '0.0.0.0', '--node-socket', '/ipc/node.socket', '--node-config', '/config/cardano-node/config.json']
depends_on:
cardano-node:
condition: service_started
healthcheck:
retries: 2000
ports:
Expand All @@ -176,7 +179,7 @@ services:

cardano-submit-api:
command: --config /config/cardano-submit-api/config.json --listen-address 0.0.0.0 --socket-path /ipc/node.socket $SUBMIT_API_ARGS
image: public.ecr.aws/e8d0p1a5/cardano-submit-api:${CARDANO_NODE_VERSION:-1.35.5}
image: ghcr.io/intersectmbo/cardano-submit-api:${CARDANO_NODE_VERSION:-8.9.2}
ports:
- 8090:8090
restart: on-failure
Expand Down Expand Up @@ -216,7 +219,7 @@ services:
POSTGRES_DB_FILE: /run/secrets/postgres_db_db_sync
POSTGRES_PASSWORD_FILE: /run/secrets/postgres_password
POSTGRES_USER_FILE: /run/secrets/postgres_user
image: postgres:${POSTGRES_VERSION:-11.5-alpine}
image: postgres:${POSTGRES_VERSION:-12.16-alpine}
healthcheck:
test: ['CMD-SHELL', 'pg_isready -U postgres']
interval: 10s
Expand Down
49 changes: 45 additions & 4 deletions nix/cardano-services/deployments/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -193,7 +193,7 @@ in
env.OVERRIDE_FUZZY_OPTIONS = "true";
};
handle-provider.enabled = true;
# asset-provider.enabled = true;
# asset-provider.enabled = true;
};

projectors = {
Expand Down Expand Up @@ -337,13 +337,13 @@ in
env.OVERRIDE_FUZZY_OPTIONS = "true";
};
handle-provider.enabled = true;
# asset-provider.enabled = true;
# asset-provider.enabled = true;
};

projectors = {
handle.enabled = true;
stake-pool.enabled = true;
# asset.enabled = true;
# asset.enabled = true;
};

values = {
Expand Down Expand Up @@ -384,7 +384,7 @@ in
env.OVERRIDE_FUZZY_OPTIONS = "true";
};
handle-provider.enabled = true;
# asset-provider.enabled = true;
# asset-provider.enabled = true;
};

projectors = {
Expand All @@ -406,6 +406,44 @@ in
};
};

"dev-preprod-resync@us-east-1@v2" = final: {
name = "${final.namespace}-cardanojs-v2";
namespace = "dev-preprod-resync";
context = "eks-devs";
network = "preprod";
region = "us-east-1";

providers = {
backend = {
enabled = true;
env.NODE_EXTRA_OPTIONS = "--trace-gc";
};
stake-pool-provider = {
enabled = true;
env.OVERRIDE_FUZZY_OPTIONS = "true";
};
handle-provider.enabled = true;
};

projectors = {
handle.enabled = true;
stake-pool.enabled = true;
};

values = {
stakepool.databaseName = "stakepoolv2";
backend.allowedOrigins = lib.concatStringsSep "," allowedOriginsDev;
backend.hostnames = ["${final.namespace}.${baseUrl}"];

pg-boss-worker.enabled = true;

blockfrost-worker.enabled = true;
cardano-services = {
ingresOrder = 98;
};
};
};

"staging-preprod@us-east-1@v2" = final: {
name = "${final.namespace}-cardanojs-v2";
namespace = "staging-preprod";
Expand Down Expand Up @@ -435,6 +473,8 @@ in
stakepool.databaseName = "stakepoolv2";
blockfrost-worker.enabled = true;
pg-boss-worker.enabled = true;
pg-boss-worker.metadata-fetch-mode = "direct";
pg-boss-worker.queues = "pool-metadata,pool-metrics,pool-rewards";
cardano-services = {
ingresOrder = 98;
};
Expand Down Expand Up @@ -905,6 +945,7 @@ in
};

"ops-preview-1@us-east-1" = final: {
name = "${final.namespace}-cardanojs-v2";
namespace = "ops-preview-1";
network = "preview";
region = "us-east-1";
Expand Down
Original file line number Diff line number Diff line change
@@ -1,20 +1,31 @@
/* eslint-disable wrap-regex */
import { TxSubmissionError, TxSubmissionErrorCode } from '@cardano-sdk/core';

// TODO: LW-9890 Map cardano-submit-api to core errors
// For now this is a very superficial mapping, we should improve it in the future
const parseStringishError = (errorData: string) => {
if (/outsideofvalidity/i.test(errorData)) {
return new TxSubmissionError(TxSubmissionErrorCode.OutsideOfValidityInterval, null, errorData);
}
if (/valuenotconserved/i.test(errorData)) {
return new TxSubmissionError(TxSubmissionErrorCode.ValueNotConserved, null, errorData);
}
if (/nonadacollateral/i.test(errorData)) {
return new TxSubmissionError(TxSubmissionErrorCode.NonAdaCollateral, null, errorData);
}
if (/incompletewithdrawals/i.test(errorData)) {
return new TxSubmissionError(TxSubmissionErrorCode.IncompleteWithdrawals, null, errorData);
}
return null;
};

export const mapCardanoTxSubmitError = (errorData: unknown): TxSubmissionError | null => {
if (typeof errorData === 'string') {
if (/outsideofvalidity/i.test(errorData)) {
return new TxSubmissionError(TxSubmissionErrorCode.OutsideOfValidityInterval, null, errorData);
}
if (/valuenotconserved/i.test(errorData)) {
return new TxSubmissionError(TxSubmissionErrorCode.ValueNotConserved, null, errorData);
}
if (/nonadacollateral/i.test(errorData)) {
return new TxSubmissionError(TxSubmissionErrorCode.NonAdaCollateral, null, errorData);
}
if (/incompletewithdrawals/i.test(errorData)) {
return new TxSubmissionError(TxSubmissionErrorCode.IncompleteWithdrawals, null, errorData);
}
return parseStringishError(errorData);
} else if (typeof errorData === 'object' && errorData) {
// cardano-submit-api started returning json instead of raw string.
// For the moment, simply stringify it. In the future we may want to make use of it.
return parseStringishError(JSON.stringify(errorData));
}
return null;
};
2 changes: 1 addition & 1 deletion packages/cardano-services-client/src/version.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// auto-generated using ../scripts/createVersionSource.js
export const apiVersion = {
assetInfo: '1.0.0',
chainHistory: '3.0.1',
chainHistory: '3.1.0',
handle: '1.0.0',
networkInfo: '1.0.0',
rewards: '1.0.0',
Expand Down
3 changes: 2 additions & 1 deletion packages/cardano-services-client/supportedVersions.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,8 @@
],
"chainHistory": [
"3.0.0",
"3.0.1"
"3.0.1",
"3.1.0"
],
"handle": [
"1.0.0"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,28 @@ describe('mapCardanoTxSubmitError', () => {
expect(mapCardanoTxSubmitError(errorData)).toBeNull();
});
});

describe('json errors', () => {
const errorData = {
contents: {
contents: {
contents: {
era: 'ShelleyBasedEraConway',
error: [
'ConwayUtxowFailure (UtxoFailure (AlonzoInBabbageUtxoPredFailure (ValueNotConservedUTxO (MaryValue (Coin 0) (MultiAsset (fromList []))) (MaryValue (Coin 4999969413825) (MultiAsset (fromList []))))))',
'ConwayUtxowFailure (UtxoFailure (AlonzoInBabbageUtxoPredFailure (BadInputsUTxO (fromList [TxIn (TxId {unTxId = SafeHash "5f968400f05638454896883ae0f34491e14d748194a10df3f5a7fe2d10f52373"}) (TxIx 1)]))))'
],
kind: 'ShelleyTxValidationError'
},
tag: 'TxValidationErrorInCardanoMode'
},
tag: 'TxCmdTxSubmitValidationError'
},
tag: 'TxSubmitFail'
};

it('can map ValueNotConservedError to TxSubmissionErrorCode.ValueNotConserved', () => {
expect(CardanoNodeUtil.isValueNotConservedError(mapCardanoTxSubmitError(errorData))).toBeTruthy();
});
});
});
6 changes: 3 additions & 3 deletions packages/cardano-services/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -180,14 +180,14 @@ for each of them can be an easy way to iterate over all the impacted models.

See [code coverage report]

[cardano db sync]: https://github.com/input-output-hk/cardano-db-sync
[cardano node]: https://github.com/input-output-hk/cardano-node
[cardano db sync]: https://github.com/IntersectMBO/cardano-db-sync
[cardano node]: https://github.com/IntersectMBO/cardano-node
[cli]: ./src/cli.ts
[code coverage report]: https://input-output-hk.github.io/cardano-js-sdk/coverage/cardano-services
[install and build]: ../../README.md#install-and-build
[ogmios]: https://ogmios.dev/
[postgresql]: https://www.postgresql.org/
[prometheus]: https://prometheus.io/
[provider]: ../core/src/Provider
[submit-api]: https://github.com/input-output-hk/cardano-node/tree/master/cardano-submit-api
[submit-api]: https://github.com/IntersectMBO/cardano-node/tree/master/cardano-submit-api
[txsubmithttpservice]: ./src/TxSubmit/TxSubmitHttpService.ts
52 changes: 10 additions & 42 deletions packages/cardano-services/config/.github/scripts/download-all.sh
Original file line number Diff line number Diff line change
@@ -1,9 +1,6 @@
#!/bin/bash

# Download configuration files from a nominated URL for a nominated network
# If p2p is enabled, create an explicit p2p version, keeping the default aligned with the production
# networks, at least until https://github.com/input-output-hk/ouroboros-network/pull/3844 has been
# inclded in a cardano-node release.

CARDANO_CONFIG_URL=$1
CARDANO_NETWORK=$2
Expand All @@ -14,47 +11,18 @@ mkdir -p \
network/$CARDANO_NETWORK/cardano-db-sync \
network/$CARDANO_NETWORK/cardano-submit-api

SOURCE_TOPOLOGY=$(wget -qO- $CARDANO_CONFIG_URL/$CARDANO_NETWORK/topology.json)
NODE_CONFIG=$(wget -qO- $CARDANO_CONFIG_URL/$CARDANO_NETWORK/config.json | jq '.ByronGenesisFile = "../genesis/byron.json" | .ShelleyGenesisFile = "../genesis/shelley.json" | .AlonzoGenesisFile = "../genesis/alonzo.json" | .ConwayGenesisFile = "../genesis/conway.json"')
DB_SYNC_CONFIG=$(wget -qO- $CARDANO_CONFIG_URL/$CARDANO_NETWORK/db-sync-config.json | jq '.NodeConfigFile = "../cardano-node/config.json"')
SUBMIT_API_CONFIG=$(wget -qO- $CARDANO_CONFIG_URL/$CARDANO_NETWORK/submit-api-config.json)
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/topology.json -O network/$CARDANO_NETWORK/cardano-node/topology.json
wget -qO- $CARDANO_CONFIG_URL/$CARDANO_NETWORK/config.json \
| jq '.ByronGenesisFile = "../genesis/byron.json" | .ShelleyGenesisFile = "../genesis/shelley.json" | .AlonzoGenesisFile = "../genesis/alonzo.json" | .ConwayGenesisFile = "../genesis/conway.json"' \
| jq '.' > network/$CARDANO_NETWORK/cardano-node/config.json
wget -qO- $CARDANO_CONFIG_URL/$CARDANO_NETWORK/db-sync-config.json \
| jq '.NodeConfigFile = "../cardano-node/config.json"' \
| jq '.' > network/$CARDANO_NETWORK/cardano-db-sync/config.json
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/submit-api-config.json -O network/$CARDANO_NETWORK/cardano-submit-api/config.json


# Genesis
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/byron-genesis.json -O network/$CARDANO_NETWORK/genesis/byron.json
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/shelley-genesis.json -O network/$CARDANO_NETWORK/genesis/shelley.json
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/alonzo-genesis.json -O network/$CARDANO_NETWORK/genesis/alonzo.json
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/conway-genesis.json -O network/$CARDANO_NETWORK/genesis/conway.json

if [ $(echo $SOURCE_TOPOLOGY | jq 'has("publicRoots")') = true ];
then
ACCESS_POINT=$(echo $SOURCE_TOPOLOGY | jq '.publicRoots[0].accessPoints[0]')

# Add separate p2p config
mkdir -p \
network/${CARDANO_NETWORK}_p2p/cardano-node \
network/${CARDANO_NETWORK}_p2p/genesis \
network/${CARDANO_NETWORK}_p2p/cardano-db-sync \
network/${CARDANO_NETWORK}_p2p/cardano-submit-api

wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/byron-genesis.json -O network/${CARDANO_NETWORK}_p2p/genesis/byron.json
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/shelley-genesis.json -O network/${CARDANO_NETWORK}_p2p/genesis/shelley.json
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/alonzo-genesis.json -O network/${CARDANO_NETWORK}_p2p/genesis/alonzo.json
wget -q $CARDANO_CONFIG_URL/$CARDANO_NETWORK/conway-genesis.json -O network/${CARDANO_NETWORK}_p2p/genesis/conway.json

echo $SOURCE_TOPOLOGY | jq '.' > network/${CARDANO_NETWORK}_p2p/cardano-node/topology.json
echo $NODE_CONFIG | jq '.' > network/${CARDANO_NETWORK}_p2p/cardano-node/config.json
echo $DB_SYNC_CONFIG | jq '.' > network/${CARDANO_NETWORK}_p2p/cardano-db-sync/config.json
echo $SUBMIT_API_CONFIG | jq '.' > network/${CARDANO_NETWORK}_p2p/cardano-submit-api/config.json

# Transform defaults to disable p2p
jq -nj --argjson address $(echo $ACCESS_POINT | jq '.address') --argjson port $(echo $ACCESS_POINT | jq '.port') '{"Producers": [{"addr": $address, "port": $port, "valency": 1 }]}' > network/$CARDANO_NETWORK/cardano-node/topology.json
# See https://github.com/input-output-hk/cardano-node/blob/0681cdeb07d81b3b088a6c14e703d03751c3d25d/cardano-node/src/Cardano/Node/Tracing/Tracers/Startup.hs#L366
echo $NODE_CONFIG | jq '.EnableP2P = false | del(.TestEnableDevelopmentNetworkProtocols)'> network/$CARDANO_NETWORK/cardano-node/config.json
echo $DB_SYNC_CONFIG | jq '.' > network/$CARDANO_NETWORK/cardano-db-sync/config.json
echo $SUBMIT_API_CONFIG | jq '.' > network/$CARDANO_NETWORK/cardano-submit-api/config.json
else
# Source config doesn't have p2p enabled, so no further transformation required
echo $SOURCE_TOPOLOGY | jq '.' > network/$CARDANO_NETWORK/cardano-node/topology.json
echo $NODE_CONFIG | jq '.' > network/$CARDANO_NETWORK/cardano-node/config.json
echo $DB_SYNC_CONFIG | jq '.' > network/$CARDANO_NETWORK/cardano-db-sync/config.json
echo $SUBMIT_API_CONFIG | jq '.' > network/$CARDANO_NETWORK/cardano-submit-api/config.json
fi
Loading

0 comments on commit 9c7e831

Please sign in to comment.