Passed
Push — master ( 6bc43d...2da2ee )
by Ahmad
07:04
created

Room.setup()   A

Complexity

Conditions 1

Size

Total Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
dl 0
loc 6
rs 10
c 0
b 0
f 0
1
# frozen_string_literal: true
2
3
# BigBlueButton open source conferencing system - http://www.bigbluebutton.org/.
4
#
5
# Copyright (c) 2018 BigBlueButton Inc. and by respective authors (see below).
6
#
7
# This program is free software; you can redistribute it and/or modify it under the
8
# terms of the GNU Lesser General Public License as published by the Free Software
9
# Foundation; either version 3.0 of the License, or (at your option) any later
10
# version.
11
#
12
# BigBlueButton is distributed in the hope that it will be useful, but WITHOUT ANY
13
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
14
# PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
15
#
16
# You should have received a copy of the GNU Lesser General Public License along
17
# with BigBlueButton; if not, see <http://www.gnu.org/licenses/>.
18
19
require 'bbb_api'
20
21
class Room < ApplicationRecord
22
  include Deleteable
23
24
  before_create :setup
25
26
  validates :name, presence: true
27
28
  belongs_to :owner, class_name: 'User', foreign_key: :user_id
29
  has_many :shared_access
30
31
  def self.admins_search(string)
32
    active_database = Rails.configuration.database_configuration[Rails.env]["adapter"]
33
    # Postgres requires created_at to be cast to a string
34
    created_at_query = if active_database == "postgresql"
35
      "created_at::text"
36
    else
37
      "created_at"
38
    end
39
40
    search_query = "rooms.name LIKE :search OR rooms.uid LIKE :search OR users.email LIKE :search" \
41
    " OR users.#{created_at_query} LIKE :search"
42
43
    search_param = "%#{string}%"
44
45
    where(search_query, search: search_param)
46
  end
47
48
  def self.admins_order(column, direction)
49
    # Include the owner of the table
50
    table = joins(:owner)
51
52
    return table.order(Arel.sql("rooms.#{column} #{direction}")) if table.column_names.include?(column) || column == "users.name"
53
54
    table
55
  end
56
57
  # Determines if a user owns a room.
58
  def owned_by?(user)
59
    user_id == user&.id
60
  end
61
62
  def shared_users
63
    User.where(id: shared_access.pluck(:user_id))
64
  end
65
66
  def shared_with?(user)
67
    return false if user.nil?
68
    shared_users.include?(user)
69
  end
70
71
  # Determines the invite path for the room.
72
  def invite_path
73
    "#{Rails.configuration.relative_url_root}/#{CGI.escape(uid)}"
74
  end
75
76
  # Notify waiting users that a meeting has started.
77
  def notify_waiting
78
    ActionCable.server.broadcast("#{uid}_waiting_channel", action: "started")
79
  end
80
81
  private
82
83
  # Generates a uid for the room and BigBlueButton.
84
  def setup
85
    self.uid = random_room_uid
86
    self.bbb_id = Digest::SHA1.hexdigest(Rails.application.secrets[:secret_key_base] + Time.now.to_i.to_s).to_s
87
    self.moderator_pw = RandomPassword.generate(length: 12)
88
    self.attendee_pw = RandomPassword.generate(length: 12)
89
  end
90
91
  # Generates a three character uid chunk.
92
  def uid_chunk
93
    charset = ("a".."z").to_a - %w(b i l o s) + ("2".."9").to_a - %w(5 8)
94
    (0...3).map { charset.to_a[rand(charset.size)] }.join
95
  end
96
97
  # Generates a random room uid that uses the users name.
98
  def random_room_uid
99
    [owner.name_chunk, uid_chunk, uid_chunk].join('-').downcase
100
  end
101
end
102