*/
class OMVModuleZFSUtil {
+ /**
+ * Get /dev/disk/by-path from /dev/sdX
+ *
+ * @return string Disk identifier
+ */
+ public static function getDiskPath($disk) {
+ preg_match("/^.*\/([A-Za-z0-9]+)$/", $disk, $identifier);
+ $cmd = "ls -la /dev/disk/by-path | grep '$identifier[1]$'";
+ OMVModuleZFSUtil::exec($cmd, $out, $res);
+ if (is_array($out)) {
+ $cols = preg_split('/[\s]+/', $out[0]);
+ return($cols[count($cols)-3]);
+ }
+ }
+
+
+ /**
+ * Get poolname from name of dataset/volume etc.
+ *
+ * @return string Name of the pool
+ */
+ public static function getPoolname($name) {
+ $tmp = preg_split('/[\/]+/', $name);
+ return($tmp[0]);
+ }
+
/**
* Get UUID of ZFS pool by name
*
* @return string UUID of the pool
*/
- public static function getUUIDbyName($name) {
- preg_match('/^([A-Za-z0-9]+)\/?.*$/', $name, $result);
- $name = $result[1];
- unset($result);
- $cmd = "zpool get guid " . $name . " 2>&1";
+ public static function getUUIDbyName($poolname) {
+ $cmd = "zpool get guid " . $poolname . " 2>&1";
OMVModuleZFSUtil::exec($cmd, $out, $res);
if (isset($out)) {
$headers = preg_split('/[\s]+/', $out[0]);
*/
public static function addMissingOMVMntEnt() {
global $xmlConfig;
- $msg = "";
$cmd = "zpool list -H -o name";
OMVModuleZFSUtil::exec($cmd, $out, $res);
foreach($out as $name) {
$pooluuid = OMVModuleZFSUtil::getUUIDbyName($name);
- if (isset($pooluuid)) {
- $pooluuid = "UUID=" . $pooluuid;
- $xpath = "//system/fstab/mntent";
- $object = $xmlConfig->get($xpath);
- $uuidexists = false;
- foreach ($object as $obj) {
- if (strcmp($pooluuid, $obj['fsname']) === 0) {
- $uuidexists = true;
- break;
- }
- }
- if (!$uuidexists) {
- $uuid = OMVUtil::uuid();
- $ds = new OMVModuleZFSDataset($name);
- $dir = $ds->getMountPoint();
- $object = array(
- "uuid" => $uuid,
- "fsname" => $pooluuid,
- "dir" => $dir,
- "type" => "zfs",
- "opts" => "rw,relatime,xattr",
- "freq" => "0",
- "passno" => "2"
- );
- $xmlConfig->set("//system/fstab",array("mntent" => $object));
- $dispatcher = &OMVNotifyDispatcher::getInstance();
- $dispatcher->notify(OMV_NOTIFY_CREATE,"org.openmediavault.system.fstab.mntent", $object);
- }
+ $xpath = "//system/fstab/mntent[fsname=" . $pooluuid . "]";
+ $mountpoint = $xmlConfig->get($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",
+ "freq" => "0",
+ "passno" => "2"
+ );
+ $xmlConfig->set("//system/fstab",array("mntent" => $object));
+ $dispatcher = &OMVNotifyDispatcher::getInstance();
+ $dispatcher->notify(OMV_NOTIFY_CREATE,"org.openmediavault.system.fstab.mntent", $object);
}
}
return null;
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,
'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);
- 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,
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);
array_push($objects,$tmp);
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',