forked from External/greenlight
130 lines
5.2 KiB
Ruby
130 lines
5.2 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/>.
|
|
|
|
Rails.application.routes.draw do
|
|
get '/health_check', to: 'health_check#all'
|
|
|
|
# Error routes.
|
|
match '/401', to: 'errors#unauthorized', via: :all, as: :unauthorized
|
|
match '/404', to: 'errors#not_found', via: :all, as: :not_found
|
|
match '/500', to: 'errors#internal_error', via: :all, as: :internal_error
|
|
|
|
# Signin/Signup routes.
|
|
get '/signin', to: 'sessions#signin', as: :signin
|
|
get '/signup', to: 'sessions#new', as: :signup
|
|
post '/signup', to: 'users#create', as: :create_user
|
|
get '/ldap_signin', to: 'sessions#ldap_signin', as: :ldap_signin
|
|
|
|
# Redirect to terms page
|
|
match '/terms', to: 'users#terms', via: [:get, :post]
|
|
|
|
# Admin resouces
|
|
resources :admins, only: [:index]
|
|
|
|
scope '/admins' do
|
|
# Panel Tabs
|
|
get '/recordings', to: 'admins#server_recordings', as: :admin_recordings
|
|
get '/site_settings', to: 'admins#site_settings', as: :admin_site_settings
|
|
get '/roles', to: 'admins#roles', as: :admin_roles
|
|
# Manage Users
|
|
get '/edit/:user_uid', to: 'admins#edit_user', as: :admin_edit_user
|
|
post '/ban/:user_uid', to: 'admins#ban_user', as: :admin_ban
|
|
post '/unban/:user_uid', to: 'admins#unban_user', as: :admin_unban
|
|
post '/invite', to: 'admins#invite', as: :invite_user
|
|
post '/approve/:user_uid', to: 'admins#approve', as: :admin_approve
|
|
get '/reset', to: 'admins#reset', as: :admin_reset
|
|
post '/undelete', to: 'admins#undelete', as: :admin_undelete
|
|
# Site Settings
|
|
post '/update_settings', to: 'admins#update_settings', as: :admin_update_settings
|
|
post '/registration_method', to: 'admins#registration_method', as: :admin_change_registration
|
|
post '/coloring', to: 'admins#coloring', as: :admin_coloring
|
|
post '/clear_cache', to: 'admins#clear_cache', as: :admin_clear_cache
|
|
# Roles
|
|
post '/role', to: 'admins#new_role', as: :admin_new_role
|
|
patch 'roles/order', to: 'admins#change_role_order', as: :admin_roles_order
|
|
post '/role/:role_id', to: 'admins#update_role', as: :admin_update_role
|
|
delete 'role/:role_id', to: 'admins#delete_role', as: :admin_delete_role
|
|
end
|
|
|
|
scope '/themes' do
|
|
get '/primary', to: 'themes#index', as: :themes_primary
|
|
end
|
|
|
|
# Password reset resources.
|
|
resources :password_resets, only: [:new, :create, :edit, :update]
|
|
|
|
# Account activation resources
|
|
scope '/account_activations' do
|
|
get '/', to: 'account_activations#show', as: :account_activation
|
|
get '/edit', to: 'account_activations#edit', as: :edit_account_activation
|
|
post '/resend', to: 'account_activations#resend', as: :resend_email
|
|
end
|
|
|
|
# User resources.
|
|
scope '/u' do
|
|
# Handles login of greenlight provider accounts.
|
|
post '/login', to: 'sessions#create', as: :create_session
|
|
|
|
# Log the user out of the session.
|
|
get '/logout', to: 'sessions#destroy'
|
|
|
|
# Account management.
|
|
get '/:user_uid/edit', to: 'users#edit', as: :edit_user
|
|
get '/:user_uid/change_password', to: 'users#change_password', as: :change_password
|
|
get '/:user_uid/delete_account', to: 'users#delete_account', as: :delete_account
|
|
patch '/:user_uid/edit', to: 'users#update', as: :update_user
|
|
delete '/:user_uid', to: 'users#destroy', as: :delete_user
|
|
|
|
# All user recordings
|
|
get '/:user_uid/recordings', to: 'users#recordings', as: :get_user_recordings
|
|
end
|
|
|
|
# Handles Omniauth authentication.
|
|
match '/auth/:provider/callback', to: 'sessions#omniauth', via: [:get, :post], as: :omniauth_session
|
|
get '/auth/failure', to: 'sessions#omniauth_fail'
|
|
post '/auth/ldap', to: 'sessions#ldap', as: :ldap_callback
|
|
|
|
# Room resources.
|
|
resources :rooms, only: [:create, :show, :destroy], param: :room_uid, path: '/'
|
|
|
|
# Join a room by UID
|
|
post '/room/join', to: 'rooms#join_specific_room', as: :join_room
|
|
|
|
# Extended room routes.
|
|
scope '/:room_uid' do
|
|
post '/', to: 'rooms#join'
|
|
patch '/', to: 'rooms#update', as: :update_room
|
|
post '/update_settings', to: 'rooms#update_settings'
|
|
post '/start', to: 'rooms#start', as: :start_room
|
|
get '/logout', to: 'rooms#logout', as: :logout_room
|
|
post '/login', to: 'rooms#login', as: :login_room
|
|
end
|
|
|
|
# Recording operations routes
|
|
scope '/:meetingID' do
|
|
# Manage recordings
|
|
scope '/:record_id' do
|
|
post '/', to: 'recordings#update', as: :update_recording
|
|
patch '/', to: 'recordings#rename', as: :rename_recording
|
|
delete '/', to: 'recordings#delete', as: :delete_recording
|
|
end
|
|
end
|
|
|
|
root to: 'main#index'
|
|
end
|