From 6b102ec01700cd39b4418d4da7ab61f8c3b85316 Mon Sep 17 00:00:00 2001 From: NeoPlays <80448387+NeoPlays@users.noreply.github.com> Date: Tue, 26 Nov 2024 14:00:11 +0100 Subject: [PATCH 1/4] FIX: Reject Requests on Logout --- launcher/src/backend/SSHService.js | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/launcher/src/backend/SSHService.js b/launcher/src/backend/SSHService.js index 290f2897c..a85aa160e 100755 --- a/launcher/src/backend/SSHService.js +++ b/launcher/src/backend/SSHService.js @@ -22,6 +22,7 @@ export class SSHService { }, 100); this.shellConn = null; this.shellStream = null; + this.loggingOut = false; } static checkExecError(err, accept_empty_result = false) { @@ -183,6 +184,7 @@ export class SSHService { async disconnect(reconnecting = false) { log.info("DISCONNECT: connectionInfo", this.connectionInfo.host); + this.loggingOut = true; try { this.connected = false; if (!reconnecting) { @@ -211,6 +213,8 @@ export class SSHService { return true; } catch (error) { return error; + } finally { + this.loggingOut = false; } } @@ -220,6 +224,7 @@ export class SSHService { } async execCommand(command) { + if (this.loggingOut) return { rc: -1, stdout: "", stderr: "Logging Out!" }; return new Promise((resolve, reject) => { let conn = this.getConnectionFromPool(); From 8da482e5043e14ebbc4106d37e9868924b461c46 Mon Sep 17 00:00:00 2001 From: NeoPlays <80448387+NeoPlays@users.noreply.github.com> Date: Tue, 26 Nov 2024 14:33:42 +0100 Subject: [PATCH 2/4] ADD: Prysm Migration --- .../update-changes/molecule/224/prepare.yml | 107 ++++++++++++++++++ .../update-changes/molecule/224/verify.yml | 29 +++++ .../tasks/2.2.4/prysm_changes.yaml | 53 +++++++++ .../tasks/2.2.4/updates-224.yaml | 6 + launcher/src/backend/ServiceManager.js | 33 ++---- .../ExternalConsensusService.js | 9 +- .../ethereum-services/NethermindService.js | 11 -- .../ethereum-services/PrysmBeaconService.js | 2 +- .../PrysmValidatorService.js | 17 +-- .../tests/unit/PrysmValidatorService.test.js | 3 +- .../components/UI/edit-page/EditScreen.vue | 1 - .../edit-page/components/modals/AddModal.vue | 4 +- .../edit-page/components/modals/AddPanel.vue | 13 --- launcher/src/components/base/BaseLayout.vue | 4 +- launcher/src/composables/validators.js | 1 - launcher/src/store/services.js | 23 ++-- 16 files changed, 232 insertions(+), 84 deletions(-) create mode 100644 controls/roles/update-changes/tasks/2.2.4/prysm_changes.yaml diff --git a/controls/roles/update-changes/molecule/224/prepare.yml b/controls/roles/update-changes/molecule/224/prepare.yml index 07e1660f4..2cac723d5 100644 --- a/controls/roles/update-changes/molecule/224/prepare.yml +++ b/controls/roles/update-changes/molecule/224/prepare.yml @@ -102,4 +102,111 @@ mevboost: [] otherServices: [] become: yes + + - name: Create PrysmBeaconService config + copy: + dest: "/etc/stereum/services/d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2.yaml" + owner: "root" + group: "root" + mode: 0644 + content: | + service: PrysmBeaconService + id: d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2 + configVersion: 1 + command: + - --accept-terms-of-use=true + - --holesky + - --datadir=/opt/app/beacon + - --block-batch-limit=512 + - --rpc-host=0.0.0.0 + - --grpc-gateway-host=0.0.0.0 + - --p2p-max-peers=100 + - --execution-endpoint=http://stereum-54c64310-1cf4-bea6-e539-b775393e2eb2:8551 + - --grpc-gateway-port=3500 + - --grpc-gateway-host=0.0.0.0 + - --grpc-gateway-corsdomain="*" + - --jwt-secret=/engine.jwt + - --monitoring-host=0.0.0.0 + - --monitoring-port=8080 + - --p2p-tcp-port=13001 + - --p2p-udp-port=12001 + - --genesis-state=/opt/app/genesis/prysm-holesky-genesis.ssz + - --checkpoint-sync-url=https://checkpoint-sync.holesky.ethpandaops.io + entrypoint: + - /app/cmd/beacon-chain/beacon-chain + env: {} + image: prysmaticlabs/prysm-beacon-chain:v5.1.2 + ports: + - 0.0.0.0:13001:13001/tcp + - 0.0.0.0:12001:12001/udp + - 127.0.0.1:4000:4000/tcp + - 127.0.0.1:3500:3500/tcp + volumes: + - /opt/stereum/prysm-d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2/beacon:/opt/app/beacon + - /opt/stereum/prysm-d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2/genesis:/opt/app/genesis + - /opt/stereum/nethermind-54c64310-1cf4-bea6-e539-b775393e2eb2/engine.jwt:/engine.jwt + user: "2000" + autoupdate: true + network: holesky + dependencies: + executionClients: + - service: NethermindService + id: 54c64310-1cf4-bea6-e539-b775393e2eb2 + consensusClients: [] + mevboost: [] + otherServices: [] + become: yes + + - name: Create PrysmValidatorService config + copy: + dest: "/etc/stereum/services/0f8ae6ed-4fb1-ad08-7219-9078373f957b.yaml" + owner: "root" + group: "root" + mode: 0644 + content: | + service: PrysmValidatorService + id: 0f8ae6ed-4fb1-ad08-7219-9078373f957b + configVersion: 1 + command: + - --accept-terms-of-use=true + - --beacon-rpc-provider=stereum-d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2:4000 + - --beacon-rpc-gateway-provider=stereum-d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2:3500,stereum-d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2:3500,stereum-d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2:3500, + - --web + - --holesky + - --datadir=/opt/app/data/db + - --keymanager-token-file=/opt/app/data/wallets/auth-token + - --wallet-dir=/opt/app/data/wallets + - --wallet-password-file=/opt/app/data/passwords/wallet-password + - --monitoring-host=0.0.0.0 + - --grpc-gateway-port=7500 + - --grpc-gateway-host=0.0.0.0 + - --grpc-gateway-corsdomain="*" + - --monitoring-host=0.0.0.0 + - --monitoring-port=8081 + - --suggested-fee-recipient=0x0000000000000000000000000000000000000000 + - --graffiti-file=/opt/app/graffitis/graffitis.yaml + - --enable-builder=true + - --enable-doppelganger=true + entrypoint: + - /app/cmd/validator/validator + env: {} + image: prysmaticlabs/prysm-validator:v5.1.2 + ports: + - 127.0.0.1:7500:7500/tcp + volumes: + - /opt/stereum/prysm-0f8ae6ed-4fb1-ad08-7219-9078373f957b/data/db:/opt/app/data/db + - /opt/stereum/prysm-0f8ae6ed-4fb1-ad08-7219-9078373f957b/data/wallets:/opt/app/data/wallets + - /opt/stereum/prysm-0f8ae6ed-4fb1-ad08-7219-9078373f957b/data/passwords:/opt/app/data/passwords + - /opt/stereum/prysm-0f8ae6ed-4fb1-ad08-7219-9078373f957b/graffitis:/opt/app/graffitis + user: "2000" + autoupdate: true + network: holesky + dependencies: + executionClients: [] + consensusClients: + - service: PrysmBeaconService + id: d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2 + mevboost: [] + otherServices: [] + become: yes #EOF diff --git a/controls/roles/update-changes/molecule/224/verify.yml b/controls/roles/update-changes/molecule/224/verify.yml index 54be09e3e..9e99578ad 100644 --- a/controls/roles/update-changes/molecule/224/verify.yml +++ b/controls/roles/update-changes/molecule/224/verify.yml @@ -15,10 +15,24 @@ src: "/etc/stereum/services/41b15ea7-12d4-49f6-8448-8a6164edef36.yaml" register: Ejector_service_configuration2_raw + # PrysmBeaconService + - name: Read PrysmBeaconService file + slurp: + src: "/etc/stereum/services/d545b944-56d5-dd8f-e6d7-51ad6ecfe7b2.yaml" + register: PrysmBeacon_service_configuration_raw + + # PrysmValidatorService + - name: Read PrysmValidatorService file + slurp: + src: "/etc/stereum/services/0f8ae6ed-4fb1-ad08-7219-9078373f957b.yaml" + register: PrysmValdiator_service_configuration_raw + - name: Parse Service configurations set_fact: Ejector_service_configuration: "{{ Ejector_service_configuration_raw['content'] | b64decode | from_yaml }}" Ejector_service_configuration2: "{{ Ejector_service_configuration2_raw['content'] | b64decode | from_yaml }}" + PrysmBeacon_service_configuration: "{{ PrysmBeacon_service_configuration_raw['content'] | b64decode | from_yaml }}" + PrysmValdiator_service_configuration: "{{ PrysmValdiator_service_configuration_raw['content'] | b64decode | from_yaml }}" - debug: msg: "{{ Ejector_service_configuration }}" @@ -30,10 +44,25 @@ - debug: msg: "{{ Ejector_service_configuration2_raw['content'] | b64decode }}" + - debug: + msg: "{{ PrysmBeacon_service_configuration }}" + - debug: + msg: "{{ PrysmBeacon_service_configuration_raw['content'] | b64decode }}" + + - debug: + msg: "{{ PrysmValdiator_service_configuration }}" + - debug: + msg: "{{ PrysmValdiator_service_configuration_raw['content'] | b64decode }}" + - assert: that: - Ejector_service_configuration.env.ORACLE_ADDRESSES_ALLOWLIST | from_yaml | select('match', '0x73181107c8D9ED4ce0bbeF7A0b4ccf3320C41d12') | length == 1 - Ejector_service_configuration.env.ORACLE_ADDRESSES_ALLOWLIST | from_yaml | select('match', '0x1Ca0fEC59b86F549e1F1184d97cb47794C8Af58d') | length == 0 - Ejector_service_configuration2.env.ORACLE_ADDRESSES_ALLOWLIST | from_yaml | select('match', '0x73181107c8D9ED4ce0bbeF7A0b4ccf3320C41d12') | length == 1 - Ejector_service_configuration2.env.ORACLE_ADDRESSES_ALLOWLIST | from_yaml | select('match', '0x1Ca0fEC59b86F549e1F1184d97cb47794C8Af58d') | length == 0 + - PrysmBeacon_service_configuration.command | select('match', 'grpc-gateway') | length == 0 + - PrysmValdiator_service_configuration.command | select('match', 'grpc-gateway') | length == 0 + - PrysmValdiator_service_configuration.command | select('match', '--beacon-rest-api-provider') | length == 1 + - PrysmValdiator_service_configuration.command | select('match', '--enable-beacon-rest-api') | length == 1 + - PrysmValdiator_service_configuration.command | select('match', '--beacon-rpc-gateway-provider') | length == 0 # EOF diff --git a/controls/roles/update-changes/tasks/2.2.4/prysm_changes.yaml b/controls/roles/update-changes/tasks/2.2.4/prysm_changes.yaml new file mode 100644 index 000000000..9af9420ed --- /dev/null +++ b/controls/roles/update-changes/tasks/2.2.4/prysm_changes.yaml @@ -0,0 +1,53 @@ +--- +- name: Read service file + slurp: + src: "{{ config_file.path }}" + register: service_configuration_raw + +- name: Parse service's configuration + set_fact: + service_configuration: "{{ service_configuration_raw['content'] | b64decode | from_yaml }}" + service_configuration_text: "{{ service_configuration_raw['content'] | b64decode }}" + +- name: Update PrysmBeacon Changes + when: service_configuration.service == "PrysmBeaconService" or service_configuration.service == "PrysmValidatorService" + block: + - name: Update grpc-gateway-corsdomain + replace: + path: "{{ config_file.path }}" + regexp: "--grpc-gateway-corsdomain" + replace: "--http-cors-domain" + + - name: Update grpc-gateway* to http* + replace: + path: "{{ config_file.path }}" + regexp: "--grpc-gateway" + replace: "--http" + + - name: Update ports + lineinfile: + path: "{{ config_file.path }}" + regexp: "[0-9]{1,3}:[0-9]{1,5}:4000" + state: absent + when: + - service_configuration.service == "PrysmBeaconService" + +- name: Update PrysmValidator Changes + when: service_configuration.service == "PrysmValidatorService" + block: + - name: get urls + when: service_configuration.command | select('match', '--beacon-rpc-gateway-provider') | length > 0 + set_fact: + urls: "{{ service_configuration.command | select('match', '--beacon-rpc-gateway-provider') | first | regex_replace('^--beacon-rpc-gateway-provider[= ]', '') | split(',') | reject('equalto', '') | map('regex_replace', '^(.*)$', 'http://\\1') | join(',') }}" + + - name: Update beacon-rpc-gateway-provider + replace: + path: "{{ config_file.path }}" + regexp: "--beacon-rpc-gateway-provider.*" + replace: "--beacon-rest-api-provider={{ urls | default('') }}" + + - name: Add enable-beacon-rest-api + replace: + path: "{{ config_file.path }}" + regexp: "--beacon-rpc-provider.*" + replace: "--enable-beacon-rest-api" diff --git a/controls/roles/update-changes/tasks/2.2.4/updates-224.yaml b/controls/roles/update-changes/tasks/2.2.4/updates-224.yaml index d3deab9df..7bd5ebe9a 100644 --- a/controls/roles/update-changes/tasks/2.2.4/updates-224.yaml +++ b/controls/roles/update-changes/tasks/2.2.4/updates-224.yaml @@ -9,3 +9,9 @@ loop: "{{ service_config_files.files }}" loop_control: loop_var: config_file + +- name: Include Prysm Changes + include_tasks: prysm_changes.yaml + loop: "{{ service_config_files.files }}" + loop_control: + loop_var: config_file diff --git a/launcher/src/backend/ServiceManager.js b/launcher/src/backend/ServiceManager.js index 3d803ef57..273c3b1b4 100755 --- a/launcher/src/backend/ServiceManager.js +++ b/launcher/src/backend/ServiceManager.js @@ -435,11 +435,16 @@ export class ServiceManager { command = "--execution-endpoint="; } if (service.service.includes("Validator")) { - filter = (e) => e.buildConsensusClientEndpoint(); - command = "--beacon-rpc-provider="; - service.command = this.addCommandConnection(service, command, dependencies, filter); - filter = (e) => e.buildConsensusClientGateway(); - command = "--beacon-rpc-gateway-provider="; + if (!service.command.includes("--enable-beacon-rest-api")) { + filter = (e) => e.buildConsensusClientEndpoint(); + command = "--beacon-rpc-provider="; + service.command = this.addCommandConnection(service, command, dependencies, filter); + filter = (e) => e.buildConsensusClientGateway(); + command = "--beacon-rpc-gateway-provider="; + } else { + filter = (e) => e.buildConsensusClientHttpEndpointUrl(); + command = "--beacon-rest-api-provider="; + } } break; case "Lodestar": @@ -683,12 +688,6 @@ export class ServiceManager { .join(); } } - if (service.service.includes("PrysmValidator") && serviceToDelete.service.includes("ExternalConsensus")) { - service.command = this.removeCommandConnection( - service.command, - serviceToDelete.env.gateway ? serviceToDelete.env.gateway : "--beacon-rpc-gateway-provider=" - ); - } //update volumes service.volumes = service.volumes.filter((v) => !v.destinationPath.includes(serviceToDelete.id)); @@ -1051,12 +1050,7 @@ export class ServiceManager { return ExternalExecutionService.buildByUserInput(args.network, args.installDir + "/externalExecution", args.source, args.jwtToken); case "ExternalConsensusService": ports = []; - return ExternalConsensusService.buildByUserInput( - args.network, - args.installDir + "/externalConsensus", - args.source, - args.gateway ? args.gateway : "" - ); + return ExternalConsensusService.buildByUserInput(args.network, args.installDir + "/externalConsensus", args.source); case "CustomService": ports = []; return CustomService.buildByUserInput( @@ -1219,10 +1213,7 @@ export class ServiceManager { .destinationPath.split("/") .slice(0, -1) .join("/"); - await this.nodeConnection.sshService.exec( - `mkdir -p ${extConnDir} && echo -e ${service.env.link} > ${extConnDir}/link.txt` + - (service.env.gateway ? ` && echo -e ${service.env.gateway} > ${extConnDir}/gateway.txt` : "") - ); + await this.nodeConnection.sshService.exec(`mkdir -p ${extConnDir} && echo -e ${service.env.link} > ${extConnDir}/link.txt`); if (service.service.includes("Execution")) { await this.nodeConnection.sshService.exec(`echo -e ${service.env.jwtToken} > ${extConnDir}/engine.jwt`); } diff --git a/launcher/src/backend/ethereum-services/ExternalConsensusService.js b/launcher/src/backend/ethereum-services/ExternalConsensusService.js index e0876e0a9..370a2eeee 100644 --- a/launcher/src/backend/ethereum-services/ExternalConsensusService.js +++ b/launcher/src/backend/ethereum-services/ExternalConsensusService.js @@ -2,15 +2,12 @@ import { NodeService } from "./NodeService"; import { ServiceVolume } from "./ServiceVolume"; export class ExternalConsensusService extends NodeService { - static buildByUserInput(network, dir, source, gateway) { + static buildByUserInput(network, dir, source) { const service = new ExternalConsensusService(); service.setId(); const workingDir = service.buildWorkingDir(dir); - const volumes = [ - new ServiceVolume(workingDir + "/link.txt", ""), - ...(gateway ? [new ServiceVolume(workingDir + "/gateway.txt", "")] : []), - ]; + const volumes = [new ServiceVolume(workingDir + "/link.txt", "")]; service.init( "ExternalConsensusService", // service service.id, // id @@ -19,7 +16,7 @@ export class ExternalConsensusService extends NodeService { null, // imageVersion [], // command [], // entrypoint - gateway ? { link: source, gateway: gateway } : { link: source }, // env + { link: source }, // env [], // ports volumes, // volumes null, // user diff --git a/launcher/src/backend/ethereum-services/NethermindService.js b/launcher/src/backend/ethereum-services/NethermindService.js index 79f8a8be9..1605b61d6 100755 --- a/launcher/src/backend/ethereum-services/NethermindService.js +++ b/launcher/src/backend/ethereum-services/NethermindService.js @@ -37,17 +37,6 @@ export class NethermindService extends NodeService { "--HealthChecks.Enabled=true", "--Pruning.Mode=Hybrid", "--Pruning.FullPruningTrigger=StateDbSize", - "--Pruning.AvailableSpaceCheckEnabled=true", - "--Pruning.CacheMb=1024", - "--Pruning.PersistenceInterval=8192", - "--Pruning.PruningBoundary=64", - "--Pruning.TrackedPastKeyCountMemoryRatio=0.1", - "--Pruning.FullPruningCompletionBehavior=None", - "--Pruning.FullPruningDisableLowPriorityWrites=false", - "--Pruning.FullPruningMaxDegreeOfParallelism=0", - "--Pruning.FullPruningMemoryBudgetMb=4000", - "--Pruning.FullPruningMinimumDelayHours=240", - "--Pruning.FullPruningThresholdMb=256000", ], // command ["./nethermind"], // entrypoint null, // env diff --git a/launcher/src/backend/ethereum-services/PrysmBeaconService.js b/launcher/src/backend/ethereum-services/PrysmBeaconService.js index c46138c14..683c33a93 100755 --- a/launcher/src/backend/ethereum-services/PrysmBeaconService.js +++ b/launcher/src/backend/ethereum-services/PrysmBeaconService.js @@ -47,7 +47,7 @@ export class PrysmBeaconService extends NodeService { `--datadir=${dataDir}`, `--block-batch-limit=512`, "--rpc-host=0.0.0.0", - "--grpc-gateway-host=0.0.0.0", + "--http-host=0.0.0.0", "--p2p-max-peers=100", `--execution-endpoint=${executionEndpoint}`, `--jwt-secret=${JWTDir}`, diff --git a/launcher/src/backend/ethereum-services/PrysmValidatorService.js b/launcher/src/backend/ethereum-services/PrysmValidatorService.js index 2373cf013..e26719a2a 100755 --- a/launcher/src/backend/ethereum-services/PrysmValidatorService.js +++ b/launcher/src/backend/ethereum-services/PrysmValidatorService.js @@ -24,12 +24,7 @@ export class PrysmValidatorService extends NodeService { const provider = consensusClients .map((client) => { - return client.buildConsensusClientEndpoint(); - }) - .join(); - const providerGateway = consensusClients - .map((client) => { - return client.buildConsensusClientGateway(); + return client.buildConsensusClientHttpEndpointUrl(); }) .join(); @@ -41,8 +36,8 @@ export class PrysmValidatorService extends NodeService { "v5.1.0", //imageVersion [ "--accept-terms-of-use=true", - `--beacon-rpc-provider=${provider}`, - `--beacon-rpc-gateway-provider=${providerGateway}`, + "--enable-beacon-rest-api", + `--beacon-rest-api-provider=${provider}`, "--web", `--${network}`, `--datadir=${dataDir}`, @@ -50,9 +45,9 @@ export class PrysmValidatorService extends NodeService { `--wallet-dir=${walletDir}`, `--wallet-password-file=${passwordDir + "/wallet-password"}`, "--monitoring-host=0.0.0.0", - "--grpc-gateway-port=7500", - "--grpc-gateway-host=0.0.0.0", - '--grpc-gateway-corsdomain="*"', + "--http-port=7500", + "--http-host=0.0.0.0", + '--http-cors-domain="*"', "--monitoring-host=0.0.0.0", "--monitoring-port=8081", "--suggested-fee-recipient=0x0000000000000000000000000000000000000000", diff --git a/launcher/src/backend/tests/unit/PrysmValidatorService.test.js b/launcher/src/backend/tests/unit/PrysmValidatorService.test.js index 4f30c88d4..2cd67caa5 100755 --- a/launcher/src/backend/tests/unit/PrysmValidatorService.test.js +++ b/launcher/src/backend/tests/unit/PrysmValidatorService.test.js @@ -29,8 +29,7 @@ test("buildConfiguration", () => { new PrysmBeaconService.PrysmBeaconService(), ]).buildConfiguration(); - expect(prysm.command).toContain("--beacon-rpc-provider=buildConsensusClientEndpoint"); - expect(prysm.command).toContain("--beacon-rpc-gateway-provider=buildConsensusClientGateway"); + expect(prysm.command).toContain("--beacon-rest-api-provider=buildConsensusClientHttpEndpointUrl"); expect(prysm.volumes).toHaveLength(4); expect(prysm.volumes).toContain("/opt/stereum/prysm-" + prysm.id + "/data/db:/opt/app/data/db"); expect(prysm.volumes).toContain("/opt/stereum/prysm-" + prysm.id + "/data/wallets:/opt/app/data/wallets"); diff --git a/launcher/src/components/UI/edit-page/EditScreen.vue b/launcher/src/components/UI/edit-page/EditScreen.vue index 6afc4ce56..55f46c36d 100644 --- a/launcher/src/components/UI/edit-page/EditScreen.vue +++ b/launcher/src/components/UI/edit-page/EditScreen.vue @@ -597,7 +597,6 @@ const addServiceHandler = (item) => { dataObject.jwtToken = item.client.config?.jwtToken; } else if (item.client.service === "ExternalConsensusService") { dataObject.source = item.client.config?.source; - dataObject.gateway = item.client.config?.gateway; } manageStore.confirmChanges.push({ diff --git a/launcher/src/components/UI/edit-page/components/modals/AddModal.vue b/launcher/src/components/UI/edit-page/components/modals/AddModal.vue index 4f201dc81..7ddf0f785 100644 --- a/launcher/src/components/UI/edit-page/components/modals/AddModal.vue +++ b/launcher/src/components/UI/edit-page/components/modals/AddModal.vue @@ -97,10 +97,8 @@ const getSubTitles = computed(() => { const externalServiceConfirmBtn = computed(() => { if (props.client.service === "ExternalExecutionService") { return props.client.config.source === "" || props.client.config.jwtToken === ""; - } else if (props.client.service === "ExternalConsensusService" && manageStore.externalConsensusSelectedService !== "prysm") { + } else if (props.client.service === "ExternalConsensusService") { return props.client.config.source === ""; - } else if (props.client.service === "ExternalConsensusService" && manageStore.externalConsensusSelectedService === "prysm") { - return props.client.config.source === "" || props.client.config.gateway === ""; } return false; }); diff --git a/launcher/src/components/UI/edit-page/components/modals/AddPanel.vue b/launcher/src/components/UI/edit-page/components/modals/AddPanel.vue index 2d279dfb0..ef95e2372 100644 --- a/launcher/src/components/UI/edit-page/components/modals/AddPanel.vue +++ b/launcher/src/components/UI/edit-page/components/modals/AddPanel.vue @@ -98,16 +98,6 @@ import { onMounted, watch, onUnmounted, ref } from 'vue'; -