Skip to content
This repository has been archived by the owner on Nov 17, 2023. It is now read-only.

Bash Script for EVM Initialization and Configuration #8

Closed
Winnode opened this issue Jul 30, 2023 · 1 comment
Closed

Bash Script for EVM Initialization and Configuration #8

Winnode opened this issue Jul 30, 2023 · 1 comment

Comments

@Winnode
Copy link

Winnode commented Jul 30, 2023

The provided bash script aims to perform initialization and configuration of the EVM (Ethereum Virtual Machine). However, there are several potential issues that need to be addressed to enhance the script's security, stability, and overall performance.

Recommended Improvements:

  1. Parameter Validation:

    • Add validation to check whether the $1 (MONIKER) and $2 (RPC URL) parameters have been provided before proceeding with the script execution. This will help prevent errors that may occur due to invalid inputs.
    • Example improvement:
      MONIKER=$1
      RPC=$2
      
      if [[ -z $MONIKER ]]; then
          echo >&2 "Invalid MONIKER"
          exit 1
      fi
      
      if [[ -z $RPC ]]; then
          echo >&2 "Invalid RPC URL"
          exit 1
      fi
  2. Error Handling:

    • Add error handling when executing the SGX_MODE=SW make build-enclave and make install commands. This will help to know if there are any issues during the compilation or installation process and provide better information about those errors.
    • Example improvement:
      cd $HOME/chain/ && git pull && SGX_MODE=SW make build-enclave
      if [ $? -ne 0 ]; then
          echo >&2 "Failed to compile SGX_MODE=SW"
          exit 1
      fi
      
      cd $HOME/chain/ && make install
      if [ $? -ne 0 ]; then
          echo >&2 "Failed to install"
          exit 1
      fi
  3. Optimize Commands:

    • Simplify some sequential commands to improve code readability and compactness.
    • Example improvement:
      cd $HOME/chain/ && git pull && SGX_MODE=SW make build-enclave && make install
  4. Appropriate Access Rights:

    • Ensure that this script is executed with appropriate access rights for the sudo rm -rf $HOMEDIR command. This command has the potential to delete directories and their contents, which could have significant impacts on the system.
    • Use with caution and ensure that root access is not misused in this script.
  5. Environment Testing:

    • Ensure that the environment required by the script is properly configured, including variables like $HOME/chain/ and external dependencies such as jq and the swisstronikd service. Make sure that all dependencies are met before running the script.
  6. Default Value Replacements:

    • Some values in the genesis.json file will be replaced. Ensure that these changes align with the needs and purposes of the initialized and configured EVM.
@MikkySnow
Copy link
Contributor

Duplicate of issue SigmaGmbH/swisstronik-chain#12

@MikkySnow MikkySnow closed this as not planned Won't fix, can't repro, duplicate, stale Aug 2, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants