add requirements and drop dependencies
This commit is contained in:
parent
7e9a78428a
commit
8fa1f41006
|
@ -1,16 +1,11 @@
|
||||||
import json
|
import json
|
||||||
import re
|
import re
|
||||||
import subprocess
|
|
||||||
from contextlib import suppress
|
from contextlib import suppress
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from enum import Enum, unique
|
|
||||||
from fractions import Fraction
|
from fractions import Fraction
|
||||||
from subprocess import PIPE, run
|
|
||||||
from typing import Iterator, List, Optional, Type, TypeVar
|
from typing import Iterator, List, Optional, Type, TypeVar
|
||||||
from warnings import catch_warnings, filterwarnings
|
|
||||||
|
|
||||||
import dateutil.parser
|
import dateutil.parser
|
||||||
import pySMART
|
|
||||||
from ereuse_utils import getter as g
|
from ereuse_utils import getter as g
|
||||||
from ereuse_utils import text
|
from ereuse_utils import text
|
||||||
from ereuse_utils.nested_lookup import (
|
from ereuse_utils.nested_lookup import (
|
||||||
|
@ -184,87 +179,6 @@ class RamModule(Component):
|
||||||
return '{} {} {}'.format(super().__str__(), self.format, self.size)
|
return '{} {} {}'.format(super().__str__(), self.format, self.size)
|
||||||
|
|
||||||
|
|
||||||
class DataStorage(Component):
|
|
||||||
@classmethod
|
|
||||||
def new(cls, lshw, hwinfo, **kwargs) -> Iterator[C]:
|
|
||||||
disks = get_nested_dicts_with_key_containing_value(lshw, 'id', 'disk')
|
|
||||||
|
|
||||||
usb_disks = list() # List of disks that are plugged in an USB host
|
|
||||||
for usb in get_nested_dicts_with_key_containing_value(lshw, 'id', 'usbhost'):
|
|
||||||
usb_disks.extend(
|
|
||||||
get_nested_dicts_with_key_containing_value(usb, 'id', 'disk')
|
|
||||||
)
|
|
||||||
|
|
||||||
for disk in (n for n in disks if n not in usb_disks):
|
|
||||||
# We can get nodes that are not truly disks as they don't have size
|
|
||||||
if 'size' in disk:
|
|
||||||
interface = DataStorage.get_interface(disk)
|
|
||||||
removable = interface == 'usb' or disk.get('capabilities', {}).get(
|
|
||||||
'removable', False
|
|
||||||
)
|
|
||||||
if not removable:
|
|
||||||
yield cls(disk, interface)
|
|
||||||
|
|
||||||
SSD = 'SolidStateDrive'
|
|
||||||
HDD = 'HardDrive'
|
|
||||||
|
|
||||||
@unique
|
|
||||||
class DataStorageInterface(Enum):
|
|
||||||
ATA = 'ATA'
|
|
||||||
USB = 'USB'
|
|
||||||
PCI = 'PCI'
|
|
||||||
|
|
||||||
def __str__(self):
|
|
||||||
return self.value
|
|
||||||
|
|
||||||
def __init__(self, node: dict, interface: str) -> None:
|
|
||||||
super().__init__(node)
|
|
||||||
self.from_lshw(node)
|
|
||||||
self.size = unit.Quantity(node['size'], node.get('units', 'B')).to('MB').m
|
|
||||||
self.interface = (
|
|
||||||
self.DataStorageInterface(interface.upper()) if interface else None
|
|
||||||
)
|
|
||||||
self._logical_name = node['logicalname']
|
|
||||||
self.variant = node['version']
|
|
||||||
|
|
||||||
with catch_warnings():
|
|
||||||
filterwarnings('error')
|
|
||||||
try:
|
|
||||||
smart = pySMART.Device(self._logical_name)
|
|
||||||
except Warning:
|
|
||||||
self.type = self.HDD
|
|
||||||
else:
|
|
||||||
self.type = self.SSD if smart.is_ssd else self.HDD
|
|
||||||
self.serial_number = self.serial_number or smart.serial
|
|
||||||
self.model = self.model or smart.model
|
|
||||||
|
|
||||||
assert 1.0 < self.size < 1000000000000000.0, 'Invalid HDD size {}'.format(
|
|
||||||
self.size
|
|
||||||
)
|
|
||||||
|
|
||||||
def __str__(self) -> str:
|
|
||||||
return '{} {} {} with {} MB'.format(
|
|
||||||
super().__str__(), self.interface, self.type, self.size
|
|
||||||
)
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def get_interface(node: dict):
|
|
||||||
interface = run(
|
|
||||||
'udevadm info '
|
|
||||||
'--query=all '
|
|
||||||
'--name={} | '
|
|
||||||
'grep '
|
|
||||||
'ID_BUS | '
|
|
||||||
'cut -c 11-'.format(node['logicalname']),
|
|
||||||
check=True,
|
|
||||||
universal_newlines=True,
|
|
||||||
shell=True,
|
|
||||||
stdout=PIPE,
|
|
||||||
).stdout
|
|
||||||
# todo not sure if ``interface != usb`` is needed
|
|
||||||
return interface.strip()
|
|
||||||
|
|
||||||
|
|
||||||
class GraphicCard(Component):
|
class GraphicCard(Component):
|
||||||
@classmethod
|
@classmethod
|
||||||
def new(cls, lshw, hwinfo, **kwargs) -> Iterator[C]:
|
def new(cls, lshw, hwinfo, **kwargs) -> Iterator[C]:
|
||||||
|
@ -279,21 +193,7 @@ class GraphicCard(Component):
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _memory(bus_info):
|
def _memory(bus_info):
|
||||||
"""The size of the memory of the gpu."""
|
"""The size of the memory of the gpu."""
|
||||||
try:
|
return None
|
||||||
# lines = cmd.run(
|
|
||||||
# 'lspci',
|
|
||||||
# '-v -s {bus} | ',
|
|
||||||
# 'grep \'prefetchable\' | ',
|
|
||||||
# 'grep -v \'non-prefetchable\' | ',
|
|
||||||
# 'egrep -o \'[0-9]{{1,3}}[KMGT]+\''.format(bus=bus_info),
|
|
||||||
# shell=True,
|
|
||||||
# ).stdout.splitlines()
|
|
||||||
# return max(
|
|
||||||
# (base2.Quantity(value).to('MiB') for value in lines), default=None
|
|
||||||
# )
|
|
||||||
return None
|
|
||||||
except subprocess.CalledProcessError:
|
|
||||||
return None
|
|
||||||
|
|
||||||
def __str__(self) -> str:
|
def __str__(self) -> str:
|
||||||
return '{} with {}'.format(super().__str__(), self.memory)
|
return '{} with {}'.format(super().__str__(), self.memory)
|
||||||
|
|
|
@ -40,3 +40,4 @@ tqdm==4.32.2
|
||||||
python-decouple==3.3
|
python-decouple==3.3
|
||||||
python-dotenv==0.14.0
|
python-dotenv==0.14.0
|
||||||
pyjwt==2.0.0a1
|
pyjwt==2.0.0a1
|
||||||
|
numpy==1.16.3
|
||||||
|
|
Reference in a new issue