Skip to content

Commit

Permalink
Merge pull request #70 from Amosel/feature/skip-binary-install
Browse files Browse the repository at this point in the history
feat(binary-install) add optional skip binary install
  • Loading branch information
niccoloraspa authored Jun 4, 2024
2 parents e7c3e7f + b5bad7b commit 8ce00e8
Showing 1 changed file with 53 additions and 39 deletions.
92 changes: 53 additions & 39 deletions i.py
Original file line number Diff line number Diff line change
Expand Up @@ -214,7 +214,7 @@ def welcome_message():
For more information, please visit https://docs.osmosis.zone
If you have an old Osmosis installation,
If you have an old Osmosis installation,
- backup any important data before proceeding
- ensure that no osmosis services are running in the background
""" + bcolors.ENDC)
Expand All @@ -233,7 +233,7 @@ def node_complete_message(using_cosmovisor, using_service, osmosis_home):
print(bcolors.OKGREEN + """
✨ Congratulations! You have successfully completed setting up an Osmosis node! ✨
""" + bcolors.ENDC)

if using_service:

if using_cosmovisor:
Expand All @@ -252,7 +252,7 @@ def node_complete_message(using_cosmovisor, using_service, osmosis_home):
print(bcolors.OKGREEN + f"osmosisd start --home {osmosis_home}" + bcolors.ENDC)



print()

# Options
Expand All @@ -270,7 +270,7 @@ def select_install():
else:
print(bcolors.RED + f"Invalid setup {args.install}. Please choose a valid setup.\n" + bcolors.ENDC)
sys.exit(1)

else:

print(bcolors.OKGREEN + """
Expand All @@ -294,7 +294,7 @@ def select_install():
print("Invalid input. Please choose a valid option.")
else:
break

if args.verbose:
clear_screen()
print(f"Chosen install: {INSTALL_CHOICES[int(choice) - 1]}")
Expand Down Expand Up @@ -346,7 +346,7 @@ def select_network():
print(bcolors.RED + "Invalid input. Please choose a valid option. Accepted values: [ 1 , 2 ] \n" + bcolors.ENDC)
else:
break

if args.verbose:
clear_screen()
print(f"Chosen network: {NETWORK_CHOICES[int(choice) - 1]}")
Expand Down Expand Up @@ -475,7 +475,7 @@ def initialize_osmosis_home(osmosis_home, moniker):
💡 You can overwrite the osmosis home using --overwrite flag.
""" + bcolors.ENDC)

choice = input("Enter your choice, or 'exit' to quit: ").strip()

if choice.lower() == "exit":
Expand All @@ -490,15 +490,15 @@ def initialize_osmosis_home(osmosis_home, moniker):

else:
print("Invalid choice. Please enter 1 or 2.")

print(f"Initializing Osmosis home directory at '{osmosis_home}'...")
try:
subprocess.run(
["rm", "-rf", osmosis_home],
["rm", "-rf", osmosis_home],
stderr=subprocess.DEVNULL, check=True)

subprocess.run(
["osmosisd", "init", moniker, "-o", "--home", osmosis_home],
["osmosisd", "init", moniker, "-o", "--home", osmosis_home],
stderr=subprocess.DEVNULL, check=True)

print("Initialization completed successfully.")
Expand Down Expand Up @@ -529,7 +529,7 @@ def select_pruning(osmosis_home):
else:
print(bcolors.RED + f"Invalid pruning setting {args.pruning}. Please choose a valid setting.\n" + bcolors.ENDC)
sys.exit(1)

else:

print(bcolors.OKGREEN + """
Expand All @@ -553,11 +553,11 @@ def select_pruning(osmosis_home):
print("Invalid input. Please choose a valid option.")
else:
break

if args.verbose:
clear_screen()
print(f"Chosen setting: {PRUNING_CHOICES[int(choice) - 1]}")

app_toml = os.path.join(osmosis_home, "config", "app.toml")

if choice == PruningChoice.DEFAULT:
Expand All @@ -572,7 +572,7 @@ def select_pruning(osmosis_home):
subprocess.run(["sed -i -E 's/pruning = \"default\"/pruning = \"custom\"/g' " + app_toml], shell=True)
subprocess.run(["sed -i -E 's/pruning-keep-recent = \"0\"/pruning-keep-recent = \"10000\"/g' " + app_toml], shell=True)
subprocess.run(["sed -i -E 's/pruning-interval = \"0\"/pruning-interval = \"" + str(primeNum) + "\"/g' " + app_toml], shell=True)

else:
print(bcolors.RED + f"Invalid pruning setting {choice}. Please choose a valid setting.\n" + bcolors.ENDC)
sys.exit(1)
Expand Down Expand Up @@ -610,10 +610,10 @@ def customize_config(home, network):

# patch config.toml
config_toml = os.path.join(home, "config", "config.toml")

peers = ','.join(TESTNET.peers)
subprocess.run(["sed -i -E 's/persistent_peers = \"\"/persistent_peers = \"" + peers + "\"/g' " + config_toml], shell=True)

# osmosis-1 configuration
elif network == NetworkChoice.MAINNET:
client_toml = os.path.join(home, "config", "client.toml")
Expand All @@ -633,7 +633,7 @@ def customize_config(home, network):
else:
print(bcolors.RED + f"Invalid network {network}. Please choose a valid setting.\n" + bcolors.ENDC)
sys.exit(1)

clear_screen()


Expand All @@ -646,8 +646,25 @@ def download_binary(network):
Raises:
SystemExit: If the binary download URL is not available for the current operating system and architecture.
"""
binary_path = os.path.join(args.binary_path, "osmosisd")
try:
# Check if osmosisd is already installed
subprocess.run([binary_path, "version"], check=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
print("osmosisd is already installed at " + bcolors.OKGREEN + f"{binary_path}" + bcolors.ENDC)
while True:
choice = input("Do you want to skip the download or re-download the file? (skip/re-download): ").strip().lower()
if choice == "skip":
print("Skipping download.")
return
elif choice == "re-download":
print("Proceeding with re-download.")
break
else:
print("Invalid input. Please enter 'skip' or 're-download'.")
except subprocess.CalledProcessError:
print("osmosisd is not installed. Proceeding with download.")

operating_system = platform.system().lower()
architecture = platform.machine()

Expand All @@ -671,16 +688,14 @@ def download_binary(network):
print(f"Binary download URL not available for {operating_system}/{architecture}")
sys.exit(0)

try:
binary_path = os.path.join(args.binary_path, "osmosisd")

print("Downloading " + bcolors.PURPLE+ "osmosisd" + bcolors.ENDC, end="\n\n")
try:
print("Downloading " + bcolors.PURPLE + "osmosisd" + bcolors.ENDC, end="\n\n")
print("from " + bcolors.OKGREEN + f"{binary_url}" + bcolors.ENDC, end=" ")
print("to " + bcolors.OKGREEN + f"{binary_path}" + bcolors.ENDC)
print()
print(bcolors.OKGREEN + "💡 You can change the path using --binary_path" + bcolors.ENDC)

subprocess.run(["wget", binary_url,"-q", "-O", "/tmp/osmosisd"], check=True)
subprocess.run(["wget", binary_url, "-q", "-O", "/tmp/osmosisd"], check=True)
os.chmod("/tmp/osmosisd", 0o755)

if platform.system() == "Linux":
Expand All @@ -690,7 +705,7 @@ def download_binary(network):
else:
subprocess.run(["mv", "/tmp/osmosisd", binary_path], check=True)

# Test binary
# Test binary
subprocess.run(["osmosisd", "version"], check=True)

print("Binary downloaded successfully.")
Expand All @@ -702,7 +717,6 @@ def download_binary(network):

clear_screen()


def download_genesis(network, osmosis_home):
"""
Downloads the genesis file for the specified network.
Expand Down Expand Up @@ -811,7 +825,7 @@ def install_snapshot_prerequisites():
else:
print("Invalid choice. Please enter 1 or 2.")

operating_system = platform.system().lower()
operating_system = platform.system().lower()
if operating_system == "linux":
print("Installing lz4...")
subprocess.run(["sudo apt-get install wget liblz4-tool aria2 -y"],
Expand All @@ -830,7 +844,7 @@ def install_snapshot_prerequisites():
def parse_snapshot_info(network):
"""
Creates a dictionary containing the snapshot information for the specified network.
It merges the snapshot information from the osmosis official snapshot JSON and
It merges the snapshot information from the osmosis official snapshot JSON and
quicksync from chianlayer https://dl2.quicksync.io/json/osmosis.json
Returns:
Expand Down Expand Up @@ -877,7 +891,7 @@ def parse_snapshot_info(network):
snapshots = json.loads(data)

for snapshot in snapshots:

if not snapshot["file"].startswith(quicksync_prefix):
continue

Expand Down Expand Up @@ -925,7 +939,7 @@ def print_snapshot_download_info(snapshot_info):

install_snapshot_prerequisites()
snapshots = parse_snapshot_info(network)

while True:

print_snapshot_download_info(snapshots)
Expand All @@ -940,7 +954,7 @@ def print_snapshot_download_info(snapshot_info):
print(bcolors.RED + "Invalid input. Please choose a valid option." + bcolors.ENDC)
else:
break

snapshot_url = snapshots[int(choice) - 1]['url']

try:
Expand Down Expand Up @@ -1006,14 +1020,14 @@ def download_cosmovisor(osmosis_home):
if architecture not in ["arm64", "amd64"]:
print(f"Unsupported architecture {architecture}.")
sys.exit(1)

if operating_system in COSMOVISOR_URL and architecture in COSMOVISOR_URL[operating_system]:
binary_url = COSMOVISOR_URL[operating_system][architecture]
else:
print(f"Binary download URL not available for {os}/{architecture}")
sys.exit(0)

try:
try:
binary_path = os.path.join(args.binary_path, "cosmovisor")

print("Downloading " + bcolors.PURPLE+ "cosmovisor" + bcolors.ENDC, end="\n\n")
Expand All @@ -1036,7 +1050,7 @@ def download_cosmovisor(osmosis_home):
else:
subprocess.run(["mv", temp_binary_path, binary_path], check=True)

# Test binary
# Test binary
subprocess.run(["cosmovisor", "help"], check=True)

print("Binary downloaded successfully.")
Expand Down Expand Up @@ -1075,7 +1089,7 @@ def setup_cosmovisor_service(osmosis_home):

if operating_system != "Linux":
return False

if not args.service:
print(bcolors.OKGREEN + f"""
Do you want to setup cosmovisor as a background service?
Expand All @@ -1097,9 +1111,9 @@ def setup_cosmovisor_service(osmosis_home):
break
elif choice == Answer.NO:
return

user = os.environ.get("USER")

unit_file_contents = f"""[Unit]
Description=Cosmovisor daemon
After=network-online.target
Expand Down Expand Up @@ -1166,9 +1180,9 @@ def setup_osmosisd_service(osmosis_home):
break
elif choice == Answer.NO:
return

user = os.environ.get("USER")

unit_file_contents = f"""[Unit]
Description=Osmosis Daemon
After=network-online.target
Expand Down

0 comments on commit 8ce00e8

Please sign in to comment.