mirror of
https://gitlab.com/kupfer/kupferbootstrap.git
synced 2025-02-23 05:35:44 -05:00
Bonus: Generalize and reuse cmd_ssh() Signed-off-by: InsanePrawn <insane.prawny@gmail.com>
144 lines
4.6 KiB
Python
144 lines
4.6 KiB
Python
import atexit
|
|
from constants import BOOTIMG, LK2ND, LOCATIONS, QHYPSTUB, ROOTFS
|
|
from fastboot import fastboot_flash
|
|
import shutil
|
|
from image import dump_bootimg, dump_lk2nd, dump_qhypstub, get_device_and_flavour, get_image_name
|
|
import os
|
|
import subprocess
|
|
import click
|
|
import tempfile
|
|
from logger import logging
|
|
|
|
|
|
@click.command(name='flash')
|
|
@click.argument('what')
|
|
@click.argument('location', required=False)
|
|
def cmd_flash(what, location):
|
|
device, flavour = get_device_and_flavour()
|
|
image_name = get_image_name(device, flavour)
|
|
|
|
if what == ROOTFS:
|
|
if location == None:
|
|
logging.info(f'You need to specify a location to flash {what} to')
|
|
exit(1)
|
|
if location not in LOCATIONS:
|
|
logging.info(f'Invalid location {location}. Choose one of {", ".join(LOCATIONS)} for location')
|
|
exit(1)
|
|
|
|
path = ''
|
|
dir = '/dev/disk/by-id'
|
|
for file in os.listdir(dir):
|
|
sanitized_file = file.replace('-', '').replace('_', '').lower()
|
|
if f'jumpdrive{location.split("-")[0]}' in sanitized_file:
|
|
path = os.path.realpath(os.path.join(dir, file))
|
|
result = subprocess.run(['lsblk', path, '-o', 'SIZE'], capture_output=True)
|
|
if result.returncode != 0:
|
|
logging.info(f'Failed to lsblk {path}')
|
|
exit(1)
|
|
if result.stdout == b'SIZE\n 0B\n':
|
|
logging.info(
|
|
f'Disk {path} has a size of 0B. That probably means it is not available (e.g. no microSD inserted or no microSD card slot installed in the device) or corrupt or defect'
|
|
)
|
|
exit(1)
|
|
if path == '':
|
|
logging.fatal(f'Unable to discover Jumpdrive')
|
|
exit(1)
|
|
|
|
image_dir = tempfile.gettempdir()
|
|
image_path = os.path.join(image_dir, f'minimal-{image_name}')
|
|
|
|
def clean_dir():
|
|
shutil.rmtree(image_dir)
|
|
|
|
atexit.register(clean_dir)
|
|
|
|
shutil.copyfile(image_name, image_path)
|
|
|
|
result = subprocess.run([
|
|
'e2fsck',
|
|
'-fy',
|
|
image_path,
|
|
])
|
|
if result.returncode != 0:
|
|
logging.fatal(f'Failed to e2fsck {image_path}')
|
|
exit(1)
|
|
|
|
result = subprocess.run([
|
|
'resize2fs',
|
|
'-M',
|
|
image_path,
|
|
])
|
|
if result.returncode != 0:
|
|
logging.fatal(f'Failed to resize2fs {image_path}')
|
|
exit(1)
|
|
|
|
if location.endswith('-file'):
|
|
part_mount = '/mnt/kupfer/fs'
|
|
if not os.path.exists(part_mount):
|
|
os.makedirs(part_mount)
|
|
|
|
def umount():
|
|
subprocess.run(
|
|
[
|
|
'umount',
|
|
'-lc',
|
|
part_mount,
|
|
],
|
|
stderr=subprocess.DEVNULL,
|
|
)
|
|
|
|
atexit.register(umount)
|
|
|
|
result = subprocess.run([
|
|
'mount',
|
|
path,
|
|
part_mount,
|
|
])
|
|
if result.returncode != 0:
|
|
logging.fatal(f'Failed to mount {path} to {part_mount}')
|
|
exit(1)
|
|
|
|
dir = os.path.join(part_mount, '.stowaways')
|
|
if not os.path.exists(dir):
|
|
os.makedirs(dir)
|
|
|
|
result = subprocess.run([
|
|
'rsync',
|
|
'--archive',
|
|
'--inplace',
|
|
'--partial',
|
|
'--progress',
|
|
'--human-readable',
|
|
image_path,
|
|
os.path.join(dir, 'kupfer.img'),
|
|
])
|
|
if result.returncode != 0:
|
|
logging.fatal(f'Failed to mount {path} to {part_mount}')
|
|
exit(1)
|
|
else:
|
|
result = subprocess.run([
|
|
'dd',
|
|
f'if={image_path}',
|
|
f'of={path}',
|
|
'bs=20M',
|
|
'iflag=direct',
|
|
'oflag=direct',
|
|
'status=progress',
|
|
'conv=sync,noerror',
|
|
])
|
|
if result.returncode != 0:
|
|
logging.info(f'Failed to flash {image_path} to {path}')
|
|
exit(1)
|
|
|
|
elif what == BOOTIMG:
|
|
path = dump_bootimg(image_name)
|
|
fastboot_flash('boot', path)
|
|
elif what == LK2ND:
|
|
path = dump_lk2nd(image_name)
|
|
fastboot_flash('lk2nd', path)
|
|
elif what == QHYPSTUB:
|
|
path = dump_qhypstub(image_name)
|
|
fastboot_flash('qhypstub', path)
|
|
else:
|
|
logging.fatal(f'Unknown what {what}')
|
|
exit(1)
|