X-Git-Url: http://git.datanom.net/omvzfs.git/blobdiff_plain/c4ed2435c5b0a0d048369b6c52fbddfcd3c08cbb..54b9d43e43e2d6ab2212ba9abbac04290de925e0:/src/Utils.php?ds=inline diff --git a/src/Utils.php b/src/Utils.php index 86d9205..5658265 100644 --- a/src/Utils.php +++ b/src/Utils.php @@ -2,12 +2,172 @@ require_once("Exception.php"); require_once("openmediavault/util.inc"); require_once("Dataset.php"); +require_once("Zvol.php"); +require_once("Vdev.php"); +require_once("Zpool.php"); /** * Helper class for ZFS module */ class OMVModuleZFSUtil { + /** + * Clears all ZFS labels on specified devices. + * Needed for blkid to display proper data. + * + */ + public static function clearZFSLabel($disks) { + foreach ($disks as $disk) { + $cmd = "zpool labelclear /dev/" . $disk . "1"; + OMVModuleZFSUtil::exec($cmd,$out,$res); + } + } + + /** + * Return all disks in /dev/sdXX used by the pool + * + * @return array An array with all the disks + */ + public static function getDevDisksByPool($name) { + $pool = new OMVModuleZFSZpool($name); + $disks = array(); + $vdevs = $pool->getVdevs(); + foreach ($vdevs as $vdev) { + $vdisks = $vdev->getDisks(); + foreach ($vdisks as $vdisk) { + if (preg_match('/^[a-z0-9]+$/', $vdisk)) { + $disks[] = $vdisk; + continue; + } + $cmd = "ls -la /dev/disk/by-path/" . $vdisk; + unset($out); + OMVModuleZFSUtil::exec($cmd,$out,$res); + if (count($out) === 1) { + if (preg_match('/^.*\/([a-z0-9]+)$/', $out[0], $match)) { + $disks[] = $match[1]; + } + } + } + } + return($disks); + } + + /** + * Deletes all shared folders pointing to the specifc path + * + */ + public static function deleteShares($name) { + global $xmlConfig; + $tmp = new OMVModuleZFSDataset($name); + $reldirpath = OMVModuleZFSUtil::getReldirpath($tmp->getMountPoint()); + $poolname = OMVModuleZFSUtil::getPoolname($name); + $pooluuid = OMVModuleZFSUtil::getUUIDbyName($poolname); + $xpath = "//system/fstab/mntent[fsname='" . $pooluuid . "']"; + $mountpoint = $xmlConfig->get($xpath); + $mntentuuid = $mountpoint['uuid']; + $xpath = "//system/shares/sharedfolder[mntentref='" . $mntentuuid . "' and reldirpath='" . $reldirpath . "']"; + $object = $xmlConfig->get($xpath); + $xmlConfig->delete($xpath); + $dispatcher = &OMVNotifyDispatcher::getInstance(); + $dispatcher->notify(OMV_NOTIFY_DELETE,"org.openmediavault.system.shares.sharedfolder",$object); + } + + /** + * Get the relative path by complete path + * + * @return string Relative path of the complet path + */ + public static function getReldirpath($path) { + $subdirs = preg_split('/\//',$path); + $reldirpath = ""; + for ($i=2;$i&1"; + OMVModuleZFSUtil::exec($cmd, $out, $res); + if (isset($out)) { + $headers = preg_split('/[\s]+/', $out[0]); + for ($i=0; $iget($xpath); + if (is_null($mountpoint)) { + $uuid = OMVUtil::uuid(); + $pool = new OMVModuleZFSZpool($name); + $dir = $pool->getMountPoint(); + $object = array( + "uuid" => $uuid, + "fsname" => $pooluuid, + "dir" => $dir, + "type" => "zfs", + "opts" => "rw,relatime,xattr,noacl", + "freq" => "0", + "passno" => "0" + ); + $xmlConfig->set("//system/fstab",array("mntent" => $object)); + $dispatcher = &OMVNotifyDispatcher::getInstance(); + $dispatcher->notify(OMV_NOTIFY_CREATE,"org.openmediavault.system.fstab.mntent", $object); + } + } + return null; + } + /** * Get an array with all ZFS objects * @@ -26,11 +186,11 @@ class OMVModuleZFSUtil { $subdirs = preg_split('/\//',$path); $root = $subdirs[0]; $tmp = array(); - + switch ($type) { case "filesystem": if (strpos($path,'/') === false) { - //This is a Pool, thus create both the Pool entry and a Filesystem entry corresponding to the Pool. + //This is a Pool $tmp = array('id'=>$prefix . $path, 'parentid'=>'root', 'name'=>$path, @@ -38,20 +198,17 @@ class OMVModuleZFSUtil { 'icon'=>'images/raid.png', 'expanded'=>$expanded, 'path'=>$path); - array_push($objects,$tmp); - $tmp = array('id'=>$prefix . $path . '/' . $path, - 'parentid'=>$prefix . $path, - 'name'=>$path, - 'type'=>'Filesystem', - 'icon'=>'images/filesystem.png', - 'path'=>$path, - 'expanded'=>$expanded); + $pool = new OMVModuleZFSZpool($path); + $tmp['size'] = $pool->getSize(); + $tmp['used'] = "n/a"; + $tmp['available'] = "n/a"; + $tmp['mountpoint'] = $pool->getMountPoint(); array_push($objects,$tmp); } else { - //This is a Filesystem other than the Pool + //This is a Filesystem preg_match('/(.*)\/(.*)$/', $path, $result); - $tmp = array('id'=>$prefix . $root . "/" . $path, - 'parentid'=>$prefix . $root . "/" . $result[1], + $tmp = array('id'=>$prefix . $path, + 'parentid'=>$prefix . $result[1], 'name'=>$result[2], 'icon'=>"images/filesystem.png", 'path'=>$path, @@ -65,19 +222,30 @@ class OMVModuleZFSUtil { //This is a standard Filesystem. $tmp['type']= ucfirst($type); } + $tmp['size'] = "n/a"; + $used = $ds->getProperty("used"); + $tmp['used'] = $used['value']; + $available = $ds->getProperty("available"); + $tmp['available'] = $available['value']; + $tmp['mountpoint'] = $ds->getMountPoint(); array_push($objects,$tmp); } break; case "volume": preg_match('/(.*)\/(.*)$/', $path, $result); - $tmp = array('id'=>$prefix . $root . "/" . $path, - 'parentid'=>$prefix . $root . "/" . $result[1], + $tmp = array('id'=>$prefix . $path, + 'parentid'=>$prefix . $result[1], 'name'=>$result[2], 'type'=>ucfirst($type), - 'icon'=>"images/zfs_disk.png", + 'icon'=>"images/save.png", 'path'=>$path, 'expanded'=>$expanded); + $vol = new OMVModuleZFSZvol(); + $tmp['size'] = $vol->getSize(); + $tmp['used'] = "n/a"; + $tmp['available'] = "n/a"; + $tmp['mountpoint'] = "n/a"; array_push($objects,$tmp); break; @@ -85,13 +253,17 @@ class OMVModuleZFSUtil { preg_match('/(.*)\@(.*)$/', $path, $result); $subdirs = preg_split('/\//',$result[1]); $root = $subdirs[0]; - $tmp = array('id'=>$prefix . $root . "/" . $path, - 'parentid'=>$prefix . $root . "/" . $result[1], + $tmp = array('id'=>$prefix . $path, + 'parentid'=>$prefix . $result[1], 'name'=>$result[2], 'type'=>ucfirst($type), 'icon'=>'images/zfs_snap.png', 'path'=>$path, 'expanded'=>$expanded); + $tmp['size'] = "n/a"; + $tmp['used'] = "n/a"; + $tmp['available'] = "n/a"; + $tmp['mountpoint'] = "n/a"; array_push($objects,$tmp); break;