lib/dcmgr/models/volume.rb in wakame-vdc-dcmgr-10.12.0 vs lib/dcmgr/models/volume.rb in wakame-vdc-dcmgr-11.06.0

- old
+ new

@@ -30,25 +30,37 @@ Fixnum :boot_dev, :null=>false, :default=>0 String :snapshot_id String :host_device_name String :guest_device_name String :export_path, :null=>false +# String :intermediate_path, :null=>false Text :transport_information Time :deleted_at Time :attached_at Time :detached_at + index :storage_pool_id index :instance_id index :snapshot_id + index :deleted_at end with_timestamps many_to_one :storage_pool many_to_one :instance plugin ArchiveChangedColumn, :histories + subset(:lives, {:deleted_at => nil}) + + RECENT_TERMED_PERIOD=(60 * 15) + # lists the volumes are available and deleted within + # RECENT_TERMED_PERIOD sec. + def_dataset_method(:alives_and_recent_termed) { + filter("deleted_at IS NULL OR deleted_at >= ?", (Time.now.utc - RECENT_TERMED_PERIOD)) + } + # serialization plugin must be defined at the bottom of all class # method calls. # Possible column data: # iscsi: # {:iqn=>'iqn.1986-03.com.sun:02:a1024afa-775b-65cf-b5b0-aa17f3476bfc', :lun=>0} @@ -56,26 +68,27 @@ class DiskError < RuntimeError; end class RequestError < RuntimeError; end def before_create - # check the volume size sp = self.storage_pool - volume_size = Volume.dataset.where(:storage_pool_id=> self.storage_pool_id).get{sum(:size)} - total_size = sp.offerring_disk_space - volume_size.to_i + volume_size = sp.volumes_dataset.lives.sum(:size).to_i + # check if the sum of available volume and new volume is under + # the limit of offering capacity. + total_size = sp.offering_disk_space - volume_size.to_i if self.size > total_size raise DiskError, "out of disk space" end + # TODO: Here may not be the right place for capacity validation. + per_account_totoal = self.class.filter(:account_id=>self.account_id).lives.sum(:size).to_i + if self.account.quota.volume_total_size < per_account_totoal + self.size.to_i + raise DiskError, "Out of account quota: #{self.account.quota.volume_total_size}, #{self.size.to_i}, #{per_account_totoal}" + end super end - def before_save - self.updated_at = Time.now - super - end - def self.get_list(account_id, *args) data = args.first vl = self.dataset.where(:account_id=>account_id) vl = vl.limit(data[:limit], data[:start]) if data[:start] && data[:limit] if data[:target] && data[:sort] @@ -132,10 +145,15 @@ :created_at => self.created_at, :attached_at => self.attached_at, :state => self.state, :instance_id => (self.instance && self.instance.canonical_uuid), :deleted_at => self.deleted_at, + :detached_at => self.detached_at, } + end + + def ready_to_take_snapshot? + %w(available attached).member?(self.state) end def create_snapshot(account_id) vs = VolumeSnapshot.create(:account_id=>account_id, :storage_pool_id=>self.storage_pool_id,