2011-05-23 15:04:40 +00:00
|
|
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @package PTA
|
|
|
|
* @subpackage Volume
|
|
|
|
* @category Models
|
|
|
|
* @author Deon George
|
|
|
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
|
|
|
* @license http://phptsmadmin.sf.net/license.html
|
|
|
|
*/
|
2012-11-26 05:57:18 +00:00
|
|
|
class Model_VOLUME extends TSM_ORM {
|
2011-05-23 15:04:40 +00:00
|
|
|
protected $_table_name = 'VOLUMES';
|
|
|
|
protected $_primary_key = 'VOLUME_NAME';
|
|
|
|
protected $_sorting = array(
|
|
|
|
'VOLUME_NAME'=>'ASC',
|
|
|
|
'STGPOOL_NAME'=>'ASC',
|
|
|
|
);
|
|
|
|
|
2011-06-26 12:20:12 +00:00
|
|
|
protected $_has_one = array(
|
|
|
|
'MEDIA'=>array('foreign_key'=>'VOLUME_NAME','far_key'=>'VOLUME_NAME'),
|
2011-06-27 04:37:11 +00:00
|
|
|
'STGPOOL'=>array('foreign_key'=>'STGPOOL_NAME','far_key'=>'STGPOOL_NAME'),
|
2011-06-26 12:20:12 +00:00
|
|
|
);
|
2011-05-23 15:04:40 +00:00
|
|
|
protected $_has_many = array(
|
|
|
|
'VOLUMEUSAGE'=>array('foreign_key'=>'VOLUME_NAME','far_key'=>'VOLUME_NAME'),
|
|
|
|
);
|
|
|
|
|
|
|
|
protected $_display_filters = array(
|
|
|
|
'LAST_READ_DATE'=>array(
|
2012-11-26 05:57:18 +00:00
|
|
|
array('TSM_ORM::date',array(':value','d-M-Y')),
|
2011-05-23 15:04:40 +00:00
|
|
|
),
|
|
|
|
'LAST_WRITE_DATE'=>array(
|
2012-11-26 05:57:18 +00:00
|
|
|
array('TSM_ORM::date',array(':value','d-M-Y')),
|
2011-05-23 15:04:40 +00:00
|
|
|
),
|
|
|
|
);
|
|
|
|
|
2011-05-27 11:08:44 +00:00
|
|
|
// Show the number of filespaces on a volume
|
|
|
|
// $dtype is BACKUP or ARCHIVE
|
|
|
|
public function getFSOnVol($dtype) {
|
|
|
|
return $this->VOLUMEUSAGE->where('COPY_TYPE','=',$dtype)->find_all()->count();
|
|
|
|
}
|
|
|
|
|
2011-05-23 15:04:40 +00:00
|
|
|
// Show the number of nodes on a volume
|
|
|
|
// $dtype is BACKUP or ARCHIVE
|
|
|
|
public function getNodesOnVol($dtype) {
|
2011-05-27 11:08:44 +00:00
|
|
|
return $this->VOLUMEUSAGE->select('NODE_NAME')->distinct(TRUE)->where('COPY_TYPE','=',$dtype)->find_all()->count();
|
2011-05-23 15:04:40 +00:00
|
|
|
}
|
2011-05-31 14:51:15 +00:00
|
|
|
|
|
|
|
public function isScratch() {
|
|
|
|
return $this->SCRATCH === 'YES' ? TRUE : FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function location() {
|
|
|
|
return $this->display('LOCATION');
|
|
|
|
}
|
2011-06-27 04:37:11 +00:00
|
|
|
|
|
|
|
// Age of a volume, based on last read/write access.
|
|
|
|
public function age() {
|
2011-06-27 05:11:32 +00:00
|
|
|
if ((! $this->LAST_READ_DATE AND ! $this->LAST_WRITE_DATE) OR $this->STATUS == 'EMPTY')
|
2011-06-27 04:37:11 +00:00
|
|
|
return 0;
|
|
|
|
else
|
|
|
|
return (int)((time()-(strtotime(strtotime($this->LAST_READ_DATE) > strtotime($this->LAST_WRITE_DATE) ? $this->LAST_WRITE_DATE : $this->LAST_READ_DATE)))/86400);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function recycle() {
|
2012-11-26 05:57:18 +00:00
|
|
|
return Kohana::$config->load('config')->tsmtapeage < $this->age() ? TRUE : FALSE;
|
2011-06-27 04:37:11 +00:00
|
|
|
}
|
2011-05-23 15:04:40 +00:00
|
|
|
}
|
|
|
|
?>
|