-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrouter_upgrade_bootstrap.py
102 lines (89 loc) · 2.76 KB
/
router_upgrade_bootstrap.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#!/usr/bin/env python
"""
NetFoundry Edge Router Upgrade bootstrap script
"""
import os
import sys
import time
import subprocess
import tarfile
from tqdm import tqdm
import requests
def cleanup_file(file_name):
"""
Cleanup a file
"""
try:
if os.path.exists(file_name):
os.remove(file_name)
except OSError:
print("ERROR: Unable to remove file ", file_name)
def compare_dates(file_name):
"""
Compare current date to file creation time, return True if it's older an 24hrs
"""
current_time_in_seconds = time.time()
if os.stat(file_name).st_atime < current_time_in_seconds - 86400:
return True
return False
def download_file(source_url):
"""
Download file & extract
"""
try:
file_name="router_upgrade.tar.gz"
response = requests.get(source_url, stream=True, timeout=120)
total_size = int(response.headers.get("content-length", 0))
block_size = 1024 # 1 Kibibyte
status_bar = tqdm(total=total_size, unit="iB", unit_scale=True, desc="Downloading")
with open(file_name, "wb") as open_file:
for data in response.iter_content(block_size):
status_bar.update(len(data))
open_file.write(data)
status_bar.close()
with tarfile.open(file_name) as downloaded_file:
for member in downloaded_file.getmembers():
downloaded_file.extract(member, "/opt/netfoundry/")
os.remove(file_name)
except OSError:
print("Error: Unable to download binaries: ")
sys.exit(1)
def root_check():
"""
Check to see if this is running as root
"""
if os.geteuid() >= 1:
print("ERROR: This script must be run with root privileges, please use sudo or run as root")
sys.exit(1)
def main():
"""
Main logic
"""
#__version__ = '1.0.0'
# change log
# 1.0.0 - initial release
# define static variables
router_upgrade_script = "/opt/netfoundry/.router_upgrade"
download_url = ("https://github.com/netfoundry/edge-router-upgrade/"
"releases/latest/download/router_upgrade.tar.gz")
# run root check
#root_check()
# only compare if file exists
do_update = False
if os.path.exists(router_upgrade_script):
# only update if it's older than 24hrs
file_comparison = compare_dates(router_upgrade_script)
if file_comparison:
do_update = True
else:
do_update = True
# only download if update is needed
if do_update:
cleanup_file(router_upgrade_script)
download_file(download_url)
# run script
sub_command = [router_upgrade_script] + sys.argv[1:]
subprocess.run(sub_command)
# main
if __name__ == '__main__':
main()