summaryrefslogtreecommitdiff
path: root/mydisks.py
blob: 2a8ae47fb165a69d7a81c58eb2ba553b192a4f71 (plain)
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
#!/usr/bin/env python

# RaidGuessFS, a FUSE pseudo-filesystem to guess RAID parameters of a damaged device
# Copyright (C) 2015 Ludovic Pouzenc <ludovic@pouzenc.fr>
#
# This file is part of RaidGuessFS.
#
# RaidGuessFS is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# RaidGuessFS is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with RaidGuessFS. If not, see <http://www.gnu.org/licenses/>

import os, sys, logging

class MyDisks():
    """Auxiliary class, managing disk layer"""

    def __init__(self, *args, **kwargs):
        self.disks = []
        self.disk_paths = []
        self.disk_count = 0
        self.disks_size = [0]
        self.max_disks = 16

    def get_disk_count(self):
        return self.disk_count

    def set_disks_path(self,disk_path_list):
        """Set the list of real filepath to disks or images"""
        self.disk_paths = disk_path_list

    def set_disk_count(self,new_disk_count):
        """Update the number of attached disks on the fly"""
        self.disk_count = min(new_disk_count,self.max_disks)
        logging.info("MyDisks.set_disk_count(%d) : setting disk_count to %d" % (new_disk_count, self.disk_count))

    def open_disks(self):
        """(re)open all disks"""
        logging.debug("Enter open_disks()")
        for fd in self.disks:
            try:
                fd.close()
            except:
                pass
        self.disks = [ None for d in range(self.disk_count) ]
        self.disks_size = [ 0 for d in range(self.disk_count) ]

        for d in range(self.disk_count):
            path = self.disk_paths[d]
            logging.debug("Try to open disk #%2d"%d)
            try:
                self.disks[d] = open(path, "r")
                self.disks_size[d] = os.lstat(path).st_size
                logging.debug("Opened disk #%2d"%d)
            except IOError as e:
                logging.error("Can't open disk #%2d ('%s') : %s"%(d, path, e.strerror))
                self.disks_size[d] = 0
            except:
                logging.error("Can't open disk #%2d ('%s') : unhandled exception"%(d, path))
                self.disks_size[d] = 0
        logging.debug("Exit. open_disks()")


    def is_readable(self,disk_no,offset,size):
        import random
        return random.randint(0,100) > 1 # FIXME : implement this (parse ddrescue log files)

    def read(self,disk_no,offset,size):
        self.disks[disk_no].seek(offset)
        return self.disks[disk_no].read(size)