1
0
Fork 0
mirror of https://github.com/dbarzin/pandora-box.git synced 2025-07-22 23:09:41 +02:00

work in progress

This commit is contained in:
dbarzin 2022-06-12 00:26:34 +02:00
parent 8191e075cf
commit 6c831b1e01
3 changed files with 138 additions and 48 deletions

View file

@ -3,6 +3,7 @@
"""Pandora-Box is a USB scaning station based on Pandora.""" """Pandora-Box is a USB scaning station based on Pandora."""
import curses import curses
from curses import wrapper
import pypandora import pypandora
import time import time
import sys import sys
@ -18,7 +19,6 @@ NO_SCAN = True
USB_AUTO_MOUNT = True USB_AUTO_MOUNT = True
PANDORA_ROOT_URL = "http://127.0.0.1:6100" PANDORA_ROOT_URL = "http://127.0.0.1:6100"
# ----------------------------------------------------------- # -----------------------------------------------------------
# Screen # Screen
# ----------------------------------------------------------- # -----------------------------------------------------------
@ -32,73 +32,132 @@ def intit_curses():
curses.mousemask(curses.ALL_MOUSE_EVENTS | curses.REPORT_MOUSE_POSITION) curses.mousemask(curses.ALL_MOUSE_EVENTS | curses.REPORT_MOUSE_POSITION)
curses.flushinp() curses.flushinp()
curses.noecho() curses.noecho()
screen.clear() # screen.clear()
"""Print status string""" """Print status string"""
def print_status(strStatus): def print_status(strStatus):
screen.addstr(12, 0, "Status : %-32s" % strStatus) global status_win
screen.refresh() #status_win.addstr(1, 1, "Status : %-32s" % strStatus, curses.color_pair(2))
#status_win.refresh()
"""Print FS Label"""
def print_fslabel(strLabel):
screen.addstr(13, 0, "Device : %-32s" % strLabel)
screen.refresh()
"""Print current action""" """Print current action"""
def print_action(strAction): def print_action(label):
screen.addstr(14, 0, "Action : %-64s" % strAction) global status_win
screen.refresh() #status_win.addstr(3, 1, "Action : %-32s" % label, curses.color_pair(2))
#status_win.refresh()
"""Print FS Label"""
def print_fslabel(label):
global status_win
status_win.addstr(1, 1, "Partition : %-32s" % label, curses.color_pair(2))
status_win.refresh()
"""Print FS Size"""
def print_size(label):
global status_win
if label == 0.0:
status_win.addstr(2, 1, "Size : ",curses.color_pair(2))
else:
status_win.addstr(2, 1, "Size : %4.1fGB " % label,curses.color_pair(2))
status_win.refresh()
"""Print FS Used Size"""
def print_used(label):
global status_win
if label == 0.0:
status_win.addstr(3, 1, "Used : ",curses.color_pair(2))
else:
status_win.addstr(3, 1, "Used : %4.1fGB " % label,curses.color_pair(2))
status_win.refresh()
def print_fstype(label):
global status_win
status_win.addstr(1, 50, "FS Type : %-32s" % label, curses.color_pair(2))
status_win.refresh()
def print_model(label):
global status_win
status_win.addstr(2, 50, "Model : %-32s" % label, curses.color_pair(2))
status_win.refresh()
def print_serial(label):
global status_win
status_win.addstr(3, 50, "Serial : %-32s" % label, curses.color_pair(2))
status_win.refresh()
"""Initialise progress bar""" """Initialise progress bar"""
def init_bar(): def init_bar():
global progress_win global progress_win
progress_win = curses.newwin(3, 62, 3, 16) progress_win = curses.newwin(3, 83, 18, 10)
progress_win.border(0) # progress_win.border(1)
progress_win.refresh()
"""Update progress bar""" """Update progress bar"""
def update_bar(progress): def update_bar(progress):
global progress_win global progress_win
rangex = (60 / float(100)) * progress if progress == 0:
pos = int(rangex) #progress_win.clear()
display = "#" progress_win.border(1)
if pos != 0: else:
progress_win.addstr(1, pos, "{}".format(display)) pos = (80 * progress) // 100
progress_win.addstr(1, pos+1, "#")
progress_win.refresh() progress_win.refresh()
def init_log():
global log_win
log_win = curses.newwin(10, 101, 22, 0)
log_win.border(0)
def log(str):
log_win.addstr(1,1,str,curses.color_pair(3))
log_win.refresh()
"""Print main screen"""
def print_screen(): def print_screen():
screen.addstr(1, 0, " ██▓███ ▄▄▄ ███▄ █ ▓█████▄ ▒█████ ██▀███ ▄▄▄ ▄▄▄▄ ▒█████ ▒██ ██▒") global status_win
screen.addstr(2, 0, " ▓██░ ██▒▒████▄ ██ ▀█ █ ▒██▀ ██▌▒██▒ ██▒▓██ ▒ ██▒▒████▄ ▓█████▄ ▒██▒ ██▒▒▒ █ █ ▒░") curses.init_pair(1, curses.COLOR_RED, curses.COLOR_BLACK)
screen.addstr(3, 0, " ▓██░ ██▓▒▒██ ▀█▄ ▓██ ▀█ ██▒░██ █▌▒██░ ██▒▓██ ░▄█ ▒▒██ ▀█▄ ▒██▒ ▄██▒██░ ██▒░░ █ ░") curses.init_pair(2, curses.COLOR_BLUE, curses.COLOR_BLACK)
screen.addstr(4, 0, " ▒██▄█▓▒ ▒░██▄▄▄▄██ ▓██▒ ▐▌██▒░▓█▄ ▌▒██ ██░▒██▀▀█▄ ░██▄▄▄▄██ ▒██░█▀ ▒██ ██░ ░ █ █ ▒ ") curses.init_pair(3, curses.COLOR_GREEN, curses.COLOR_BLACK)
screen.addstr(5, 0, " ▒██▒ ░ ░ ▓█ ▓██▒▒██░ ▓██░░▒████▓ ░ ████▓▒░░██▓ ▒██▒ ▓█ ▓██▒ ░▓█ ▀█▓░ ████▓▒░▒██▒ ▒██▒") title_win = curses.newwin(12, 101, 0, 0)
screen.addstr(6, 0, " ▒▓▒░ ░ ░ ▒▒ ▓▒█░░ ▒░ ▒ ▒ ▒▒▓ ▒ ░ ▒░▒░▒░ ░ ▒▓ ░▒▓░ ▒▒ ▓▒█░ ░▒▓███▀▒░ ▒░▒░▒░ ▒▒ ░ ░▓ ░") title_win.border(0)
screen.addstr(7, 0, " ░▒ ░ ▒ ▒▒ ░░ ░░ ░ ▒░ ░ ▒ ▒ ░ ▒ ▒░ ░▒ ░ ▒░ ▒ ▒▒ ░ ▒░▒ ░ ░ ▒ ▒░ ░░ ░▒ ░") title_win.addstr(1, 1, " ██▓███ ▄▄▄ ███▄ █ ▓█████▄ ▒█████ ██▀███ ▄▄▄ ▄▄▄▄ ▒█████ ▒██ ██▒",curses.color_pair(1))
screen.addstr(8, 0, " ░░ ░ ▒ ░ ░ ░ ░ ░ ░ ░ ░ ░ ▒ ░░ ░ ░ ▒ ░ ░ ░ ░ ░ ▒ ░ ░ ") title_win.addstr(2, 1, " ▓██░ ██▒▒████▄ ██ ▀█ █ ▒██▀ ██▌▒██▒ ██▒▓██ ▒ ██▒▒████▄ ▓█████▄ ▒██▒ ██▒▒▒ █ █ ▒░",curses.color_pair(1))
screen.addstr(9, 0, " ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ") title_win.addstr(3, 1, " ▓██░ ██▓▒▒██ ▀█▄ ▓██ ▀█ ██▒░██ █▌▒██░ ██▒▓██ ░▄█ ▒▒██ ▀█▄ ▒██▒ ▄██▒██░ ██▒░░ █ ░",curses.color_pair(1))
screen.addstr(10, 0, " ░ ░ ") title_win.addstr(4, 1, " ▒██▄█▓▒ ▒░██▄▄▄▄██ ▓██▒ ▐▌██▒░▓█▄ ▌▒██ ██░▒██▀▀█▄ ░██▄▄▄▄██ ▒██░█▀ ▒██ ██░ ░ █ █ ▒ ",curses.color_pair(1))
title_win.addstr(5, 1, " ▒██▒ ░ ░ ▓█ ▓██▒▒██░ ▓██░░▒████▓ ░ ████▓▒░░██▓ ▒██▒ ▓█ ▓██▒ ░▓█ ▀█▓░ ████▓▒░▒██▒ ▒██▒",curses.color_pair(1))
title_win.addstr(6, 1, " ▒▓▒░ ░ ░ ▒▒ ▓▒█░░ ▒░ ▒ ▒ ▒▒▓ ▒ ░ ▒░▒░▒░ ░ ▒▓ ░▒▓░ ▒▒ ▓▒█░ ░▒▓███▀▒░ ▒░▒░▒░ ▒▒ ░ ░▓ ░",curses.color_pair(1))
title_win.addstr(7, 1, " ░▒ ░ ▒ ▒▒ ░░ ░░ ░ ▒░ ░ ▒ ▒ ░ ▒ ▒░ ░▒ ░ ▒░ ▒ ▒▒ ░ ▒░▒ ░ ░ ▒ ▒░ ░░ ░▒ ░",curses.color_pair(1))
title_win.addstr(8, 1, " ░░ ░ ▒ ░ ░ ░ ░ ░ ░ ░ ░ ░ ▒ ░░ ░ ░ ▒ ░ ░ ░ ░ ░ ▒ ░ ░ ",curses.color_pair(1))
title_win.addstr(9, 1, " ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ",curses.color_pair(1))
title_win.addstr(10, 1, " ░ ░ ",curses.color_pair(1))
title_win.refresh()
status_win = curses.newwin(5, 101, 12, 0)
status_win.border(0)
print_status("WAITING") print_status("WAITING")
print_fslabel("") print_fslabel("")
print_size(0.0)
print_used(0.0)
print_fstype("")
print_action("") print_action("")
print_model("")
print_serial("")
init_bar() init_bar()
update_bar(1) update_bar(0)
init_log()
log('Ready.')
"""Closes curses"""
def end_curses(): def end_curses():
curses.endwin() curses.endwin()
curses.flushinp() curses.flushinp()
# ----------------------------------------------------------- # -----------------------------------------------------------
# device # Device
# ----------------------------------------------------------- # -----------------------------------------------------------
"""Mount USB device"""
def mount_device(device): def mount_device(device):
if USB_AUTO_MOUNT: if USB_AUTO_MOUNT:
found = False found = False
@ -111,12 +170,20 @@ def mount_device(device):
print_action("Mounted at {}".format(partition.mountpoint)) print_action("Mounted at {}".format(partition.mountpoint))
found = True found = True
loop += 1 loop += 1
if loop < 10:
return partition.mountpoint
else:
return ""
else: else:
print_action("mount device to /media/box") print_action("mount device to /media/box")
res = os.system("pmount " + device.device_node + " box") res = os.system("pmount " + device.device_node + " box")
# print("Return type: ", res) if res == 1:
return "/media/box"
else:
return ""
"""Unmount USB device"""
def umount_device(): def umount_device():
if not USB_AUTO_MOUNT: if not USB_AUTO_MOUNT:
print_action("unmount device /media/box") print_action("unmount device /media/box")
@ -124,6 +191,7 @@ def umount_device():
# print("Return type: ", res) # print("Return type: ", res)
"""Main device loop"""
def device_loop(): def device_loop():
context = pyudev.Context() context = pyudev.Context()
monitor = pyudev.Monitor.from_netlink(context) monitor = pyudev.Monitor.from_netlink(context)
@ -131,17 +199,31 @@ def device_loop():
for device in iter(monitor.poll, None): for device in iter(monitor.poll, None):
if device.get("ID_FS_USAGE") == "filesystem" and device.device_node[5:7] == "sd": if device.get("ID_FS_USAGE") == "filesystem" and device.device_node[5:7] == "sd":
if device.action == "add": if device.action == "add":
# print("New device {}".format(device.device_node))
mount_device(device)
# display device type # display device type
print_status("KEY INSERTED") print_status("KEY INSERTED")
print_fslabel(device.get("ID_FS_LABEL")) print_fslabel(device.get("ID_FS_LABEL"))
print_fstype(device.get("ID_PART_TABLE_TYPE"))
print_model(device.get("ID_MODEL"))
print_serial(device.get("ID_SERIAL_SHORT"))
# Mount device
mount_point = mount_device(device)
statvfs=os.statvfs(mount_point)
print_size(statvfs.f_frsize * statvfs.f_blocks // 1024 // 1024 / 1024)
print_used(statvfs.f_frsize * (statvfs.f_blocks - statvfs.f_bfree) // 1024 // 1024 / 1024)
# fake scan
loading = 0
while loading < 100:
loading += 1
time.sleep(0.03)
update_bar(loading)
if device.action == "remove": if device.action == "remove":
print_status("WAITING") print_status("WAITING")
print_action("Device removed") print_action("Device removed")
print_fslabel("") print_fslabel("")
umount_device() umount_device()
update_bar(0)
# ----------------------------------------------------------- # -----------------------------------------------------------
@ -149,6 +231,7 @@ def device_loop():
# ----------------------------------------------------------- # -----------------------------------------------------------
"""Scan a mount point with Pandora"""
def scan(mountPoint): def scan(mountPoint):
pp = pypandora.PyPandora(root_url=PANDORA_ROOT_URL) pp = pypandora.PyPandora(root_url=PANDORA_ROOT_URL)
@ -173,7 +256,8 @@ def scan(mountPoint):
# -------------------------------------- # --------------------------------------
def pandorabox(): """Main entry point"""
def main(stdscr):
try: try:
intit_curses() intit_curses()
print_screen() print_screen()
@ -187,4 +271,4 @@ def pandorabox():
if __name__ == "__main__": if __name__ == "__main__":
pandorabox() wrapper(main)

View file

@ -27,6 +27,11 @@ def printDeviceInfo(dev):
print("USB driver: %s" % dev.get("ID_USB_DRIVER")) print("USB driver: %s" % dev.get("ID_USB_DRIVER"))
print("Path id: %s" % dev.get("ID_PATH")) print("Path id: %s" % dev.get("ID_PATH"))
print('Usage: %s' % dev.get("ID_FS_USAGE")) print('Usage: %s' % dev.get("ID_FS_USAGE"))
print('Serial short: %s' % dev.get("ID_SERIAL_SHORT"))
print('Serial: %s' % dev.get("ID_SERIAL"))
print('Model: %s' % dev.get("ID_MODEL_ID"))
print(os.stat(dev.get("DEVNAME")))
print("</BLOCK INFORMATION>") print("</BLOCK INFORMATION>")
print("") print("")
@ -47,6 +52,9 @@ for device in iter(monitor.poll, None):
for partition in psutil.disk_partitions(): for partition in psutil.disk_partitions():
if partition.device == device.device_node: if partition.device == device.device_node:
print("Mounted at {}".format(partition.mountpoint)) print("Mounted at {}".format(partition.mountpoint))
statvfs=os.statvfs(partition.mountpoint)
print("size %4.1fGB"% (statvfs.f_frsize * statvfs.f_blocks // 1024 // 1024 / 1024))
print("used %4.1fGB"% (statvfs.f_frsize * (statvfs.f_blocks - statvfs.f_bfree) // 1024 // 1024 / 1024))
found = True found = True
loop += 1 loop += 1
else: else:

View file

@ -14,11 +14,9 @@ def initBar():
def updateBar(progress): def updateBar(progress):
global progress_win global progress_win
rangex = (60 / float(100)) * progress pos = (60 * progress) // 100
pos = int(rangex)
display = "#"
if pos != 0 : if pos != 0 :
progress_win.addstr(1, pos, "{}".format(display)) progress_win.addstr(1, pos, "{}".format("#"))
progress_win.refresh() progress_win.refresh()
@ -31,5 +29,5 @@ while loading < 100:
time.sleep(1) time.sleep(1)
curses.endwin() #curses.endwin()
curses.flushinp() curses.flushinp()