require 'bigbluebutton_api' class BigbluebuttonServer < ActiveRecord::Base has_many :rooms, :class_name => 'BigbluebuttonRoom', :foreign_key => 'server_id', :dependent => :nullify has_many :recordings, :class_name => 'BigbluebuttonRecording', :foreign_key => 'server_id', :dependent => :nullify validates :name, :presence => true, :uniqueness => true, :length => { :minimum => 1, :maximum => 500 } validates :url, :presence => true, :uniqueness => true, :length => { :maximum => 500 }, :format => { :with => /http:\/\/.*\/bigbluebutton\/api/, :message => I18n.t('bigbluebutton_rails.servers.errors.url_format') } validates :param, :presence => true, :uniqueness => true, :length => { :minimum => 3 }, :format => { :with => /^[a-zA-Z\d_]+[a-zA-Z\d_-]*[a-zA-Z\d_]+$/, :message => I18n.t('bigbluebutton_rails.servers.errors.param_format') } validates :salt, :presence => true, :length => { :minimum => 1, :maximum => 500 } validates :version, :presence => true, :inclusion => { :in => ['0.7', '0.8'] } attr_accessible :name, :url, :version, :salt, :param # Array of BigbluebuttonMeeting attr_reader :meetings after_initialize :init before_validation :set_param # Returns the API object (BigBlueButton::BigBlueButtonAPI defined in # bigbluebutton-api-ruby) associated with this server. def api if @api.nil? @api = BigBlueButton::BigBlueButtonApi.new(self.url, self.salt, self.version.to_s, false) end @api end # Fetches the meetings currently created in the server (running or not). # # Using the response, updates meetings with a list of BigbluebuttonMeeting # objects. # # Triggers API call: getMeetings. def fetch_meetings response = self.api.get_meetings # updates the information in the rooms that are currently in BBB @meetings = [] response[:meetings].each do |attr| room = BigbluebuttonRoom.find_by_server_id_and_meetingid(self.id, attr[:meetingID]) if room.nil? room = BigbluebuttonRoom.new(:server => self, :meetingid => attr[:meetingID], :name => attr[:meetingID], :attendee_password => attr[:attendeePW], :moderator_password => attr[:moderatorPW], :external => true, :private => true) else room.update_attributes(:attendee_password => attr[:attendeePW], :moderator_password => attr[:moderatorPW]) end room.running = attr[:running] @meetings << room end end # Sends a call to the BBB server to publish or unpublish a recording or a set # of recordings. # ids:: IDs of the recordings that will be affected. Accepts the same format # accepted by BigBlueButtonApi::publish_recordings # publish:: Publish or unpublish the recordings? # # Triggers API call: publishRecordings. def send_publish_recordings(ids, publish) self.api.publish_recordings(ids, publish) # Update #published in all recordings ids = ids.split(",") if ids.instance_of?(String) # "id1,id2" to ["id1", "id2"] ids.each do |id| recording = BigbluebuttonRecording.find_by_recordid(id.strip) recording.update_attributes(:published => publish) unless recording.nil? end end # Sends a call to the BBB server to delete a recording or a set or recordings. # ids:: IDs of the recordings that will be affected. Accepts the same format # accepted by BigBlueButtonApi::delete_recordings # # Triggers API call: deleteRecordings. def send_delete_recordings(ids) self.api.delete_recordings(ids) end # Sends a call to the BBB server to get the list of recordings and updates # the database with these recordings. # filter:: filters to be used, uses the same format accepted by # BigBlueButtonApi::get_recordings. Can filter by meetingID and/or # metadata values. # # Triggers API call: getRecordings. def fetch_recordings(filter={}) logger.info "Fetching recordings for the server #{self.inspect} with filter: #{filter.inspect}" recordings = self.api.get_recordings(filter) if recordings and recordings[:recordings] BigbluebuttonRecording.sync(self, recordings[:recordings]) end end def to_param self.param end protected def init # fetched attributes @meetings = [] end # if :param wasn't set, sets it as :name downcase and parameterized def set_param if self.param.blank? self.param = self.name.parameterize.downcase unless self.name.nil? end end end