Chamilo is a learning management system focused on ease of use and accessibility
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
chamilo-lms/plugin/openmeetings/lib/openmeetings_plugin.class.php

86 lines
3.5 KiB

<?php
class OpenMeetingsPlugin extends Plugin
{
public $is_course_plugin = true;
//When creating a new course this settings are added to the course
public $course_settings = array(
array('name' => 'openmeetings_record_and_store', 'type' => 'checkbox')
);
static function create()
{
static $result = null;
return $result ? $result : $result = new self();
}
protected function __construct()
{
parent::__construct('2.0', 'Francis Gonzales', array('tool_enable' => 'boolean', 'host' =>'text', 'user' => 'text', 'pass' => 'text'));
}
function install()
{
$table = Database::get_main_table('plugin_openmeetings');
// id is the internal unique ID (keeps track of historical sessions
// status is 0 for closed, 1 for open (available)
// room_id is a reference to the meeting ID on the OpenMeetings server.
// Any c_id + session_id occurence gets a unique new meeting ID to avoid issues with the number of rooms, as indicated in https://issues.apache.org/jira/browse/OPENMEETINGS-802#comment-13860340
$sql = "CREATE TABLE IF NOT EXISTS $table (
id INT unsigned NOT NULL auto_increment PRIMARY KEY,
c_id INT unsigned NOT NULL DEFAULT 0,
session_id INT unsigned NOT NULL DEFAULT 0,
room_id INT unsigned NOT NULL DEFAULT 0,
meeting_name VARCHAR(255) NOT NULL DEFAULT '',
attendee_pw VARCHAR(255) NOT NULL DEFAULT '',
moderator_pw VARCHAR(255) NOT NULL DEFAULT '',
record INT NOT NULL DEFAULT 0,
status INT NOT NULL DEFAULT 0,
created_at DATETIME NOT NULL,
closed_at DATETIME,
calendar_id INT DEFAULT 0,
welcome_msg TEXT NOT NULL DEFAULT '')";
Database::query($sql);
//Installing course settings
$this->install_course_fields_in_all_courses();
}
function uninstall()
{
$t_settings = Database::get_main_table(TABLE_MAIN_SETTINGS_CURRENT);
$t_options = Database::get_main_table(TABLE_MAIN_SETTINGS_OPTIONS);
$t_tool = Database::get_course_table(TABLE_TOOL_LIST);
//New settings
$sql = "DELETE FROM $t_settings WHERE variable = 'openmeetings_tool_enable'";
Database::query($sql);
$sql = "DELETE FROM $t_settings WHERE variable = 'openmeetings_pass'";
Database::query($sql);
$sql = "DELETE FROM $t_settings WHERE variable = 'openmeetings_user'";
Database::query($sql);
$sql = "DELETE FROM $t_settings WHERE variable = 'openmeetings_host'";
Database::query($sql);
//Old settings deleting just in case
$sql = "DELETE FROM $t_settings WHERE variable = 'openmeetings_plugin'";
Database::query($sql);
$sql = "DELETE FROM $t_options WHERE variable = 'openmeetings_plugin'";
Database::query($sql);
// $sql = "DELETE FROM $t_settings WHERE variable = 'openmeetings_plugin_host'";
// Database::query($sql);
// $sql = "DELETE FROM $t_settings WHERE variable = 'openmeetings_plugin_salt'";
// Database::query($sql);
//hack to get rid of Database::query warning (please add c_id...)
$sql = "DELETE FROM $t_tool WHERE name = 'openmeetings' AND c_id = c_id";
Database::query($sql);
$sql = "DROP TABLE IF EXISTS plugin_openmeetings";
Database::query($sql);
//Deleting course settings
$this->uninstall_course_fields_in_all_courses();
}
}