forked from External/greenlight
* Fix wrong conditional (reported by LGTM) (#1477)
Signed-off-by: Stefan Weil <sw@weilnetz.de>
Co-authored-by: Ahmad Farhat <ahmad.af.farhat@gmail.com>
* Bump rack from 2.2.2 to 2.2.3 (#1839)
Bumps [rack](https://github.com/rack/rack) from 2.2.2 to 2.2.3.
- [Release notes](https://github.com/rack/rack/releases)
- [Changelog](https://github.com/rack/rack/blob/master/CHANGELOG.md)
- [Commits](https://github.com/rack/rack/compare/v2.2.2...2.2.3)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
* [FIX] Unable to edit long recording names #1776 (#1780)
* Allow to set a filter for LDAP authentication
* [FIX] Unable to edit long recording names #1776
Co-authored-by: François Ménabé <francois.menabe@unistra.fr>
Co-authored-by: farhatahmad <ahmad.af.farhat@gmail.com>
* Desgin for Manage Users Tabs (#1777)
* Update _subtitle.html.erb
* Update _manage_users_tags.html.erb
* Update admins.scss
* Update _primary_themes.scss
* Update _manage_users_tags.html.erb
* Minor style changes to manage users (#1845)
* Maintenance banner moved to admin site (#1775)
* initial
* finish
* travis fixes
* travis again
* not required
* Co-authored-by: Tobias Fiebig <t.fiebig@tudelft.nl> (#1296)
Co-authored-by: Ahmad Farhat <ahmad.af.farhat@gmail.com>
* Enhance Room OpenGraph Metadata (#1601)
* Revert "Enhance Room OpenGraph Metadata (#1601)" (#1852)
This reverts commit 3b007c233a.
* GRN2-xx: Tab title now displays the current page name (#1853)
* Tab title now displays the current page name
* Added page title for the rest of the pages
* Split Site Settings into 3 different tabs (#1858)
* Split Site Settings into 3 different tabs
* Fix copyright
* Added redirect to correct tab
* Make sure settings are displaying when they should
* Update en.yml (#1857)
* Build images for alpha branches (#1867)
* Upgraded jquery to latest version (#1896)
* Added favicon tag (#1898)
* Fixed XSS issue with role name (#1899)
* Update path for coloring redirect (#1908)
* Added a fourth section to the room uid (#1910)
* Fixed issue with insecure room sharing removal (#1914)
* Fixes typo (#1917)
Fixes typo: successfully was written incorrect.
* Fixed order of rooms in server rooms (#1915)
* Change default room sort to latest activity (#1919)
* GRN2-xx: Small changes/improvements to the recording settings (#1851)
* Small changes/improvements to the recording settings
* Replaced room warning with info flash
* Added global setting to enable/disable the recording consent feature
* Replace Legal with Terms (#1931)
* Added a more friendly OpenGraph description when invited to join a room (#1932)
* Fixed issue causing maintenance banner not to hide correctly (#1933)
* Hide recording menu and recording list when it is disabled (#1935)
* Hide recording menu and recording list when it is disabled
* Hide recording list when disabled
* GRN2-xx: Added an auto-refresh after 2 mins while waiting for room to start (#1947)
* Added an auto-refresh after 2 mins while waiting for room to start
* Fixed random issue with test case
* GRN2-xx: Added ability to preupload presentations to rooms (#1895)
* Added ability to preupload presentations to rooms (#1868)
* Added setting to site settings and allowed admins to change the presentation
* Added AWS S3 and GCS Storage ENV variables
* Added check to ensure file extension is correct
* Added icon to remove presentation
* Added testcases for preupload
* Add nginx redirect to solve issue with relative root
* Record title, instead of room name, in the popup (#1924)
* Update _public_recording_row.html.erb
* Update _recording_row.html.erb
Co-authored-by: Stefan Weil <sw@weilnetz.de>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: beckerr-rzht <beckerr@hochschule-trier.de>
Co-authored-by: François Ménabé <francois.menabe@unistra.fr>
Co-authored-by: MrKeksi <mrkeksi@users.noreply.github.com>
Co-authored-by: yanosz <yanosz@users.noreply.github.com>
Co-authored-by: Moritz Schlarb <moschlar@metalabs.de>
Co-authored-by: chronikum <34622984+chronikum@users.noreply.github.com>
Co-authored-by: Mitsutaka Sato <miztaka@honestyworks.jp>
Co-authored-by: hiroshisuga <45039819+hiroshisuga@users.noreply.github.com>
128 lines
4.1 KiB
Ruby
128 lines
4.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
# BigBlueButton open source conferencing system - http://www.bigbluebutton.org/.
|
|
#
|
|
# Copyright (c) 2018 BigBlueButton Inc. and by respective authors (see below).
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify it under the
|
|
# terms of the GNU Lesser General Public License as published by the Free Software
|
|
# Foundation; either version 3.0 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# BigBlueButton is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
# PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public License along
|
|
# with BigBlueButton; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
require 'bbb_api'
|
|
require 'uri'
|
|
|
|
module ApplicationHelper
|
|
# Determines which providers can show a login button in the login modal.
|
|
def iconset_providers
|
|
providers = configured_providers & [:google, :twitter, :office365, :ldap]
|
|
|
|
providers.delete(:twitter) if session[:old_twitter_user_id]
|
|
|
|
providers
|
|
end
|
|
|
|
# Generates the login URL for a specific provider.
|
|
def omniauth_login_url(provider)
|
|
if provider == :ldap
|
|
ldap_signin_path
|
|
else
|
|
"#{Rails.configuration.relative_url_root}/auth/#{provider}"
|
|
end
|
|
end
|
|
|
|
# Determines if a form field needs the is-invalid class.
|
|
def form_is_invalid?(obj, key)
|
|
'is-invalid' unless obj.errors.messages[key].empty?
|
|
end
|
|
|
|
# Return all the translations available in the client side through javascript
|
|
def current_translations
|
|
@translations ||= I18n.backend.send(:translations)
|
|
@translations[I18n.locale]
|
|
end
|
|
|
|
# Return the fallback translations available in the client side through javascript
|
|
def fallback_translations
|
|
@fallback_translations ||= I18n.backend.send(:translations)
|
|
@fallback_translations[I18n.default_locale]
|
|
end
|
|
|
|
# Returns 'active' if the current page is the users home page (used to style header)
|
|
def active_home
|
|
home_actions = %w[show cant_create_rooms]
|
|
return "active" if params[:controller] == "admins" && params[:action] == "index" && current_user.has_role?(:super_admin)
|
|
return "active" if params[:controller] == "rooms" && home_actions.include?(params[:action])
|
|
""
|
|
end
|
|
|
|
# Returns the action method of the current page
|
|
def active_page
|
|
route = Rails.application.routes.recognize_path(request.env['PATH_INFO'])
|
|
|
|
route[:action]
|
|
end
|
|
|
|
def role_colour(role)
|
|
role.colour || Rails.configuration.primary_color_default
|
|
end
|
|
|
|
def translated_role_name(role)
|
|
if role.name == "denied"
|
|
I18n.t("roles.banned")
|
|
elsif role.name == "pending"
|
|
I18n.t("roles.pending")
|
|
elsif role.name == "admin"
|
|
I18n.t("roles.admin")
|
|
elsif role.name == "user"
|
|
I18n.t("roles.user")
|
|
else
|
|
role.name
|
|
end
|
|
end
|
|
|
|
def can_reset_password
|
|
# Check if admin is editting user and user is a greenlight account
|
|
Rails.configuration.enable_email_verification &&
|
|
Rails.application.routes.recognize_path(request.env['PATH_INFO'])[:action] == "edit_user" &&
|
|
@user.greenlight_account?
|
|
end
|
|
|
|
def google_analytics_url
|
|
"https://www.googletagmanager.com/gtag/js?id=#{ENV['GOOGLE_ANALYTICS_TRACKING_ID']}"
|
|
end
|
|
|
|
# Checks to make sure the image url returns 200 and is of type image
|
|
def valid_url?(input)
|
|
url = URI.parse(input)
|
|
|
|
# Don't allow reference to own site
|
|
return false if url.host == request.host
|
|
|
|
# Make a GET request and validate content type
|
|
http = Net::HTTP.new(url.host, url.port)
|
|
http.use_ssl = (url.scheme == "https")
|
|
|
|
http.start do |web|
|
|
response = web.head(url.request_uri)
|
|
return response.code == "200" && response['Content-Type'].start_with?('image')
|
|
end
|
|
rescue
|
|
false
|
|
end
|
|
|
|
# Specifies which title should be the tab title and returns original string
|
|
def title(page_title)
|
|
# Only set the content_for if not already set on the page so that only the first title appears as the tab title
|
|
content_for(:page_title) { page_title } if content_for(:page_title).blank?
|
|
page_title
|
|
end
|
|
end
|