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

- old
+ new

@@ -1,110 +1,42 @@ # -*- coding: utf-8 -*- -require 'statemachine' module Dcmgr::Models class StoragePool < AccountResource taggable 'sp' - with_timestamps - STATAS_TYPE_REGISTERING = "registering" - STATAS_TYPE_ONLINE = "online" - STATAS_TYPE_DEGRADE = "degrade" - STATAS_TYPE_FAILED = "failed" - STATAS_TYPE_DEREGISTERED = "deregistered" - - STATUS_MSGS = { - STATAS_TYPE_REGISTERING => :registering, - STATAS_TYPE_ONLINE => :online, - STATAS_TYPE_DEGRADE => :degrade, - STATAS_TYPE_FAILED => :failed, - STATAS_TYPE_DEREGISTERED => :deregistered - } - inheritable_schema do String :node_id, :null=>false String :export_path, :null=>false - String :status, :null=>false, :default=>STATAS_TYPE_REGISTERING - Fixnum :offerring_disk_space, :null=>false, :unsigned=>true + Fixnum :offering_disk_space, :null=>false, :unsigned=>true String :transport_type, :null=>false String :storage_type, :null=>false String :ipaddr, :null=>false String :snapshot_base_path, :null=>false index :node_id end + with_timestamps one_to_many :volumes one_to_many :volume_snapshots - many_to_one :storage_agents + many_to_one :node, :class=>Isono::Models::NodeState, :key=>:node_id, :primary_key=>:node_id def before_validation export_path = self.export_path if export_path =~ /^(\/[a-z0-9]+)+$/ export_path = export_path.split('/') export_path.shift self.export_path = export_path.join('/') end end - def state_machine - model = self - st = Statemachine.build do - superstate :storage_condition do - trans :registering, :on_success, :online - trans :registering, :on_error, :degrade - trans :online, :on_success, :online - trans :online, :on_error, :degrade - trans :degrade, :on_success, :online - trans :degrade, :on_error, :degrade - - event :on_fail, :failed - event :on_deregistered, :deregistered - end - - trans :failed, :on_success, :online - trans :failed, :on_error, :degrade - trans :failed, :on_deregistered, :deregistered - - on_entry_of :registering, proc { - model.status = STATAS_TYPE_REGISTERING - } - - on_entry_of :online, proc { - model.status = STATAS_TYPE_ONLINE - } - - on_entry_of :degrade, proc { - model.status = STATAS_TYPE_DEGRADE - } - - on_entry_of :failed, proc { - model.status = STATAS_TYPE_FAILED - } - - on_entry_of :deregistered, proc { - model.status = STATAS_TYPE_DEREGISTERED - } - end - - if self[:status] - if st.has_state(STATUS_MSGS[self[:status]].to_sym) - st.state = STATUS_MSGS[self[:status]].to_sym - else - raise "Unknown state: #{self[:status]}" - end - else - st.reset - end - st - end - def self.create_pool(params) self.create(:account_id => params[:account_id], :node_id => params[:node_id], - :offerring_disk_space => params[:offerring_disk_space], + :offering_disk_space => params[:offering_disk_space], :transport_type => params[:transport_type], :storage_type => params[:storage_type], :export_path => params[:export_path], :ipaddr => params[:ipaddr], :snapshot_base_path => params[:snapshot_base_path]) @@ -123,8 +55,23 @@ def create_volume(account_id, size, snapshot_id=nil) v = Volume.create(:account_id => account_id, :storage_pool_id => self.id, :snapshot_id => snapshot_id, :size =>size) + end + + # Show status of the agent. + def status + node.nil? ? :offline : node.state + end + + def to_hash + super.merge({:status=>self.status}) + end + + def to_api_document + h = to_hash + h.delete(:node_id) + h end end end