Merge branch '1.10.x' of github.com:chamilo/chamilo-lms into 1.10.x

1.10.x
Yannick Warnier 9 years ago
commit 1032df0f8e
  1. 5
      main/cron/import_csv.php
  2. 6
      main/dashboard/dashboard_controller.php
  3. 3
      main/dashboard/index.php
  4. 26
      main/dropbox/dropbox_functions.inc.php
  5. 1
      main/dropbox/dropbox_init.inc.php
  6. 3
      main/dropbox/index.php
  7. 4
      main/help/faq.php
  8. 5
      main/help/help.php
  9. 2
      main/inc/ajax/lp.ajax.php
  10. 22
      main/inc/lib/course.lib.php
  11. 89
      main/inc/lib/diagnoser.lib.php
  12. 1
      main/inc/lib/events_dispatcher.class.php
  13. 30
      main/inc/lib/formvalidator/FormValidator.class.php
  14. 2
      main/inc/lib/geometry.lib.php
  15. 8
      main/inc/lib/glossary.lib.php
  16. 44
      main/inc/lib/lp_item.lib.php
  17. 15
      main/inc/lib/message.lib.php
  18. 55
      main/inc/lib/social.lib.php
  19. 5
      main/inc/lib/statistics.lib.php
  20. 1
      main/inc/lib/system_announcements.lib.php
  21. 20
      main/inc/lib/urlmanager.lib.php
  22. 1
      main/inc/lib/user_api_key_manager.class.php
  23. 6
      main/inc/lib/usergroup.lib.php
  24. 2
      main/inc/lib/webservices/MessagesWebService.class.php
  25. 1
      main/inc/lib/webservices/WebService.class.php
  26. 3
      main/link/link_goto.php
  27. 4
      main/messages/inbox.php
  28. 15
      main/mySpace/coaches.php
  29. 3
      main/mySpace/current_courses.php
  30. 8
      main/mySpace/progression.php
  31. 1
      main/mySpace/user_edit.php
  32. 2
      main/mySpace/users.php
  33. 22
      main/newscorm/learnpath.class.php
  34. 2
      main/newscorm/learnpathItem.class.php
  35. 10
      main/newscorm/lp_controller.php
  36. 12
      main/newscorm/scorm.class.php
  37. 1
      main/social/groups.php
  38. 12
      main/social/my_skills_report.php
  39. 31
      main/webservices/access_url.php
  40. 76
      main/webservices/client_soap.php
  41. 36
      main/webservices/lp.php
  42. 437
      main/webservices/registration.soap.php
  43. 6
      src/Chamilo/CoreBundle/Component/HTMLPurifier/Filter/AllowIframes.php

@ -965,12 +965,13 @@ class ImportCsv
foreach ($data as $row) {
$row = $this->cleanCourseRow($row);
$courseCode = CourseManager::get_course_id_from_original_id(
$courseId = CourseManager::get_course_id_from_original_id(
$row['extra_' . $this->extraFieldIdNameList['course']],
$this->extraFieldIdNameList['course']
);
$courseInfo = api_get_course_info($courseCode);
$courseInfo = api_get_course_info_by_id($courseId);
$courseCode = $courseInfo['code'];
if (empty($courseInfo)) {
// Create

@ -2,9 +2,11 @@
/* For licensing terms, see /license.txt */
/**
* Controller script. Prepares the common background variables to give to the scripts corresponding to
* Controller script. Prepares the common background
* variables to give to the scripts corresponding to
* the requested action
* This file contains class used like controller, it should be included inside a dispatcher file (e.g: index.php)
* This file contains class used like controller,
* it should be included inside a dispatcher file (e.g: index.php)
* @author Christian Fasanando <christian1827@gmail.com>
*
* @package chamilo.dashboard

@ -1,7 +1,8 @@
<?php
/* For licensing terms, see /license.txt */
/**
* Template (front controller in MVC pattern) used for distpaching to the controllers depend on the current action
* Template (front controller in MVC pattern) used for distpaching to
* the controllers depend on the current action
* @author Christian Fasanando <christian1827@gmail.com>
* @package chamilo.dashboard
*/

@ -222,7 +222,10 @@ function store_move($id, $target, $part)
$dropbox_cnf = getDropboxConf();
$course_id = api_get_course_int_id();
if ((isset($id) AND $id != '') AND (isset($target) AND $target != '') AND (isset($part) AND $part != '')) {
if ((isset($id) AND $id != '') AND
(isset($target) AND $target != '') AND
(isset($part) AND $part != '')
) {
if ($part == 'received') {
$sql = "UPDATE ".$dropbox_cnf["tbl_post"]."
@ -250,7 +253,8 @@ function store_move($id, $target, $part)
}
/**
* This functions displays all teh possible actions that can be performed on multiple files. This is the dropdown list that
* This functions displays all teh possible actions that can be
* performed on multiple files. This is the dropdown list that
* appears below the sortable table of the sent / or received files.
*
* @return html value for the dropdown list
@ -660,8 +664,9 @@ function display_add_form($dropbox_unid, $viewReceivedCategory, $viewSentCategor
/*
* Show groups
*/
if (($dropbox_person -> isCourseTutor || $dropbox_person -> isCourseAdmin)
&& dropbox_cnf('allowGroup') || dropbox_cnf('allowStudentToStudent')) {
if (($dropbox_person->isCourseTutor || $dropbox_person->isCourseAdmin)
&& dropbox_cnf('allowGroup') || dropbox_cnf('allowStudentToStudent')
) {
$complete_group_list_for_dropbox = GroupManager::get_group_list(null, dropbox_cnf('courseId'));
if (count($complete_group_list_for_dropbox) > 0) {
@ -842,7 +847,6 @@ function removeMoreIfMailing($file_id)
}
}
/**
* Function that finds a given config setting
*
@ -956,7 +960,11 @@ function store_add_dropbox()
// separate functions: store_new_dropbox, store_new_mailing, store_just_upload
if ($dropbox_overwrite) {
$dropbox_person = new Dropbox_Person($_user['user_id'], api_is_course_admin(), api_is_course_tutor());
$dropbox_person = new Dropbox_Person(
$_user['user_id'],
api_is_course_admin(),
api_is_course_tutor()
);
foreach ($dropbox_person->sentWork as $w) {
if ($w->title == $dropbox_filename) {
@ -1320,7 +1328,8 @@ function generate_html_overview($files, $dont_show_columns = array(), $make_link
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
* @version march 2006
*/
function get_total_number_feedback($file_id = '') {
function get_total_number_feedback($file_id = '')
{
$dropbox_cnf = getDropboxConf();
$course_id = api_get_course_int_id();
$sql = "SELECT COUNT(feedback_id) AS total, file_id
@ -1340,7 +1349,8 @@ function get_total_number_feedback($file_id = '') {
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
* @version march 2006
*/
function check_number_feedback($key, $array) {
function check_number_feedback($key, $array)
{
if (is_array($array)) {
if (array_key_exists($key, $array)) {
return $array[$key];

@ -235,7 +235,6 @@ if (dropbox_cnf('allowOverwrite')) {
function checkfile(str)
{
ind = str.lastIndexOf('/'); //unix separator
if (ind == -1) ind = str.lastIndexOf('\\\'); //windows separator
filename = str.substring(ind+1, str.length);

@ -75,7 +75,8 @@ if ($action == 'addreceivedcategory' || $action == 'addsentcategory') {
if (api_get_session_id() != 0 && !api_is_allowed_to_session_edit(false, true)) {
api_not_allowed();
}
display_addcategory_form($_POST['category_name'], '', $_GET['action']);
$categoryName = isset($_POST['category_name']) ? $_POST['category_name'] : '';
display_addcategory_form($categoryName, '', $_GET['action']);
}
// Editing a category: displaying the form

@ -6,9 +6,7 @@
*
* @package chamilo.help
*/
/**
* Code
*/
require_once '../inc/global.inc.php';
$help_name = isset($_GET['open']) ? Security::remove_XSS($_GET['open']) : null;

@ -6,10 +6,9 @@
*
* @package chamilo.help
*/
/**
* Code
*/
require_once '../inc/global.inc.php';
$help_name = isset($_GET['open']) ? Security::remove_XSS($_GET['open']) : null;
if (empty($help_name)) {
api_not_allowed(true);

@ -250,7 +250,7 @@ switch ($action) {
$forumThread = $lpItem->getForumThread($course_id, $sessionId);
if (empty($forumThread)) {
$lpItem->createForumTthread($forumId);
$lpItem->createForumThread($forumId);
$forumThread = $lpItem->getForumThread($course_id, $sessionId);
}

@ -5774,4 +5774,26 @@ class CourseManager
return $params;
}
/**
* Get the course id based on the original id and field name in the extra fields.
* Returns 0 if course was not found
*
* @param string $original_course_id_value Original course id
* @param string $original_course_id_name Original field name
* @return int Course id
*/
public static function get_course_id_from_original_id($original_course_id_value, $original_course_id_name)
{
$extraFieldValue = new ExtraFieldValue('course');
$value = $extraFieldValue->get_item_id_from_field_variable_and_field_value(
$original_course_id_name,
$original_course_id_value
);
if ($value) {
return $value['item_id'];
}
return 0;
}
}

@ -13,20 +13,21 @@
*/
class Diagnoser
{
const STATUS_OK = 1;
const STATUS_WARNING = 2;
const STATUS_ERROR = 3;
const STATUS_INFORMATION = 4;
/**
* The status's
* Contructor
*/
const STATUS_OK = 1;
const STATUS_WARNING = 2;
const STATUS_ERROR = 3;
const STATUS_INFORMATION = 4;
function __construct() {
public function __construct()
{
}
function show_html() {
$sections = array('chamilo', 'php', 'mysql', 'webserver');
public function show_html()
{
$sections = array('chamilo', 'php', 'database', 'webserver');
if (!in_array(trim($_GET['section']), $sections)) {
$current_section = 'chamilo';
@ -37,7 +38,6 @@ class Diagnoser
$html = '<div class="tabbable"><ul class="nav nav-tabs">';
foreach ($sections as $section) {
if ($current_section == $section) {
$html .= '<li class="active">';
} else {
@ -68,7 +68,7 @@ class Diagnoser
* Functions to get the data for the chamilo diagnostics
* @return array of data
*/
function get_chamilo_data()
public function get_chamilo_data()
{
$array = array();
$writable_folders = array(
@ -107,7 +107,8 @@ class Diagnoser
* Functions to get the data for the php diagnostics
* @return array of data
*/
function get_php_data() {
public function get_php_data()
{
$array = array();
// General Functions
@ -270,18 +271,48 @@ class Diagnoser
* Functions to get the data for the mysql diagnostics
* @return array of data
*/
function get_mysql_data() {
public function get_database_data()
{
$array = array();
$em = Database::getManager();
$connection = $em->getConnection();
$host = $connection->getHost();
$db = $connection->getDatabase();
$port = $connection->getPort();
$driver = $connection->getDriver()->getName();
$array[] = $this->build_setting(
self :: STATUS_INFORMATION,
'[Database]',
'driver',
'',
$driver, null, null, get_lang('Driver')
);
// A note: Maybe it would be better if all "MySQL"-like variable names and words on the page to be replaced with "Database"-like ones.
$array[] = $this->build_setting(
self :: STATUS_INFORMATION,
'[Database]',
'host',
'',
$host, null, null, get_lang('MysqlHostInfo')
);
//$array[] = $this->build_setting(self :: STATUS_INFORMATION, '[MySQL]', 'host', 'http://www.php.net/manual/en/function.mysql-get-host-info.php', Database::get_host_info(), null, null, get_lang('MysqlHostInfo'));
/*
$array[] = $this->build_setting(self :: STATUS_INFORMATION, '[MySQL]', 'mysql_get_server_info()', 'http://www.php.net/manual/en/function.mysql-get-server-info.php', Database::get_server_info(), null, null, get_lang('MysqlServerInfo'));
$array[] = $this->build_setting(
self :: STATUS_INFORMATION,
'[Database]',
'port',
'',
$port, null, null, get_lang('Port')
);
$array[] = $this->build_setting(self :: STATUS_INFORMATION, '[MySQL]', 'mysql_get_proto_info()', 'http://www.php.net/manual/en/function.mysql-get-proto-info.php', Database::get_proto_info(), null, null, get_lang('MysqlProtoInfo'));
$array[] = $this->build_setting(self :: STATUS_INFORMATION, '[MySQL]', 'mysql_get_client_info()', 'http://www.php.net/manual/en/function.mysql-get-client-info.php', Database::get_client_info(), null, null, get_lang('MysqlClientInfo'));*/
$array[] = $this->build_setting(
self :: STATUS_INFORMATION,
'[Database]',
'Database name',
'',
$db, null, null, get_lang('Name')
);
return $array;
}
@ -290,7 +321,8 @@ class Diagnoser
* Functions to get the data for the webserver diagnostics
* @return array of data
*/
function get_webserver_data() {
public function get_webserver_data()
{
$array = array();
$array[] = $this->build_setting(self :: STATUS_INFORMATION, '[SERVER]', '$_SERVER["SERVER_NAME"]', 'http://be.php.net/reserved.variables.server', $_SERVER["SERVER_NAME"], null, null, get_lang('ServerNameInfo'));
@ -320,8 +352,7 @@ class Diagnoser
/**
* Additional functions needed for fast integration
*/
function build_setting($status, $section, $title, $url, $current_value, $expected_value, $formatter, $comment, $img_path = null) {
public function build_setting($status, $section, $title, $url, $current_value, $expected_value, $formatter, $comment, $img_path = null) {
switch ($status) {
case self :: STATUS_OK :
$img = 'bullet_green.png';
@ -363,11 +394,13 @@ class Diagnoser
* @param $url
* @return string the url
*/
function get_link($title, $url) {
public function get_link($title, $url)
{
return '<a href="' . $url . '" target="about:bank">' . $title . '</a>';
}
function format_yes_no_optional($value) {
public function format_yes_no_optional($value)
{
$return = '';
switch($value) {
case 0:
@ -384,11 +417,13 @@ class Diagnoser
}
function format_yes_no($value) {
function format_yes_no($value)
{
return $value ? get_lang('Yes') : get_lang('No');
}
function format_on_off($value) {
function format_on_off($value)
{
$value = intval($value);
if ($value > 1) {
// Greater than 1 values are shown "as-is", they may be interpreted as "On" later.

@ -1,5 +1,4 @@
<?php
include_once api_get_path(CONFIGURATION_PATH).'events.conf.php';
/**
* Class EventsDispatcher

@ -713,6 +713,36 @@ EOT;
return $this->addElement('select', $name, $label, $options, $attributes);
}
/**
* @param $name
* @param $label
* @param $collection
* @param array $attributes
* @param bool $addNoneOption
* @param string $textCallable set a function getStringValue() by default __toString()
*
* @return HTML_QuickForm_element
*/
public function addSelectFromCollection($name, $label, $collection, $attributes = array(), $addNoneOption = false, $textCallable = '')
{
$options = [];
if ($addNoneOption) {
$options[0] = get_lang('None');
}
if (!empty($collection)) {
foreach ($collection as $item) {
$text = $item;
if (!empty($textCallable)) {
$text = $item->$textCallable();
}
$options[$item->getId()] = $text;
}
}
return $this->addElement('select', $name, $label, $options, $attributes);
}
/**
* @param string $label
* @param string $text

@ -5,7 +5,7 @@
* @package chamilo.include.geometry
*/
DEFINE('DEBUG', false);
define('DEBUG', false);
/**
* poly_init - build the array which will store the image of the polygone
* @param max[x] X resolution

@ -12,7 +12,7 @@ class GlossaryManager
/**
* Get all glossary terms
* @author Isaac Flores <isaac.flores@dokeos.com>
* @return Array Contain glossary terms
* @return array Contain glossary terms
*/
public static function get_glossary_terms()
{
@ -37,7 +37,7 @@ class GlossaryManager
* Get glossary term by glossary id
* @author Isaac Flores <florespaz@bidsoftperu.com>
* @param int $glossary_id
* @return String The glossary description
* @return string The glossary description
*/
public static function get_glossary_term_by_glossary_id ($glossary_id)
{
@ -58,8 +58,8 @@ class GlossaryManager
/**
* Get glossary term by glossary id
* @author Isaac Flores <florespaz_isaac@hotmail.com>
* @param String The glossary term name
* @return String The glossary description
* @param string The glossary term name
* @return string The glossary description
*/
public static function get_glossary_term_by_glossary_name ($glossary_name)
{

@ -11,28 +11,28 @@
*/
class LpItem
{
public $c_id=0;
public $id=0;
public $lp_id=0;
public $item_type="";
public $ref="";
public $title="";
public $description="";
public $path="";
public $min_score=0;
public $max_score=0;
public $mastery_score=0;
public $parent_item_id=0;
public $previous_item_id=0;
public $next_item_id=0;
public $display_order=0;
public $prerequisite="";
public $parameters="";
public $launch_data="";
public $max_time_allowed="";
public $terms="";
public $search_did=0;
public $audio="";
public $c_id = 0;
public $id = 0;
public $lp_id = 0;
public $item_type = "";
public $ref = "";
public $title = "";
public $description = "";
public $path = "";
public $min_score = 0;
public $max_score = 0;
public $mastery_score = 0;
public $parent_item_id = 0;
public $previous_item_id = 0;
public $next_item_id = 0;
public $display_order = 0;
public $prerequisite = "";
public $parameters = "";
public $launch_data = "";
public $max_time_allowed = "";
public $terms = "";
public $search_did = 0;
public $audio = "";
public function __construct($in_c_id=0, $in_id=0)
{

@ -69,7 +69,9 @@ class MessageManager
return false;
}
$sql = "SELECT * FROM $table
WHERE user_receiver_id=".api_get_user_id()." AND msg_status=".MESSAGE_STATUS_UNREAD;
WHERE
user_receiver_id=".api_get_user_id()." AND
msg_status=".MESSAGE_STATUS_UNREAD;
$result = Database::query($sql);
$i = Database::num_rows($result);
@ -108,6 +110,7 @@ class MessageManager
WHERE $condition_msg_status AND user_receiver_id=".api_get_user_id();
$sql_result = Database::query($sql);
$result = Database::fetch_array($sql_result);
return $result['number_messages'];
}
@ -645,8 +648,9 @@ class MessageManager
$path_message_attach = $path_user_info['dir'].'message_attachments/';
if (is_file($path_message_attach.$path)) {
if (rename($path_message_attach.$path, $path_message_attach.$new_path)) {
$sql_upd = "UPDATE $table_message_attach set path='$new_path' WHERE id ='$attach_id'";
Database::query($sql_upd);
$sql = "UPDATE $table_message_attach set path='$new_path'
WHERE id ='$attach_id'";
Database::query($sql);
}
}
}
@ -799,7 +803,10 @@ class MessageManager
}
$sql = "SELECT * FROM $table_message
WHERE parent_id='$parent_id' AND msg_status <> ".MESSAGE_STATUS_OUTBOX." $condition_group_id
WHERE
parent_id='$parent_id' AND
msg_status <> ".MESSAGE_STATUS_OUTBOX."
$condition_group_id
ORDER BY send_date DESC $condition_limit ";
$rs = Database::query($sql);
$data = array();

@ -291,7 +291,9 @@ class SocialManager extends UserManager
$tbl_message = Database::get_main_table(TABLE_MESSAGE);
$sql = 'SELECT user_receiver_id, send_date,title,content
FROM '.$tbl_message.'
WHERE user_sender_id = '.intval($user_id).' AND msg_status = '.MESSAGE_STATUS_INVITATION_PENDING;
WHERE
user_sender_id = '.intval($user_id).' AND
msg_status = '.MESSAGE_STATUS_INVITATION_PENDING;
$res = Database::query($sql);
while ($row = Database::fetch_array($res, 'ASSOC')) {
$list_friend_invitation[$row['user_receiver_id']] = $row;
@ -724,10 +726,7 @@ class SocialManager extends UserManager
$show,
array('shared_profile', 'groups', 'group_edit', 'member_list', 'waiting_list', 'invite_friends')
)) {
$links = '<ul class="nav nav-pills nav-stacked">';
$active = $show == 'home' ? 'active' : null;
$links .= '
<li class="home-icon ' . $active . '">
@ -813,9 +812,7 @@ class SocialManager extends UserManager
}
if ($show == 'shared_profile') {
$links = '<ul class="nav nav-pills nav-stacked">';
// My own profile
if ($show_full_profile && $user_id == intval(api_get_user_id())) {
$links .= '
@ -897,7 +894,9 @@ class SocialManager extends UserManager
}
// Check if I already sent an invitation message
$invitation_sent_list = SocialManager::get_list_invitation_sent_by_user_id(api_get_user_id());
$invitation_sent_list = SocialManager::get_list_invitation_sent_by_user_id(
api_get_user_id()
);
if (isset($invitation_sent_list[$user_id]) && is_array($invitation_sent_list[$user_id]) && count($invitation_sent_list[$user_id]) > 0) {
$links .= '<li><a href="'.api_get_path(WEB_CODE_PATH).'social/invitations.php">'.Display::return_icon('invitation.png', get_lang('YouAlreadySentAnInvitation')).'&nbsp;&nbsp;'.get_lang('YouAlreadySentAnInvitation').'</a></li>';
@ -909,13 +908,13 @@ class SocialManager extends UserManager
$links .= '</ul>';
$html .= Display::panelCollapse(
get_lang('SocialNetwork'),
$links,
'social-network-menu',
null,
'sn-sidebar',
'sn-sidebar-collapse'
);
get_lang('SocialNetwork'),
$links,
'social-network-menu',
null,
'sn-sidebar',
'sn-sidebar-collapse'
);
if ($show_full_profile && $user_id == intval(api_get_user_id())) {
$personal_course_list = UserManager::get_personal_session_course_list($user_id);
@ -1207,6 +1206,7 @@ class SocialManager extends UserManager
case SOCIAL_RIGHT_PLUGIN:
break;
}
return $content;
}
/**
@ -1325,12 +1325,24 @@ class SocialManager extends UserManager
$start = Database::escape_string($start);
$limit = intval($limit);
$sql = "SELECT id, user_sender_id,user_receiver_id, send_date, content, parent_id,
(SELECT ma.path FROM $tblMessageAttachment ma WHERE ma.message_id = tm.id ) as path,
(SELECT ma.filename FROM $tblMessageAttachment ma WHERE ma.message_id = tm.id ) as filename
FROM $tblMessage tm
WHERE user_receiver_id = $userId
AND send_date > '$start' ";
$sql = "
SELECT
id,
user_sender_id,
user_receiver_id,
send_date,
content,
parent_id,
(SELECT ma.path FROM $tblMessageAttachment ma
WHERE ma.message_id = tm.id ) as path,
(SELECT ma.filename FROM $tblMessageAttachment ma
WHERE ma.message_id = tm.id ) as filename
FROM $tblMessage tm
WHERE
user_receiver_id = $userId AND
send_date > '$start'
";
$sql .= (empty($messageStatus) || is_null($messageStatus)) ? '' : " AND msg_status = '$messageStatus' ";
$sql .= (empty($parentId) || is_null($parentId)) ? '' : " AND parent_id = '$parentId' ";
$sql .= " ORDER BY send_date DESC LIMIT $offset, $limit ";
@ -1563,6 +1575,7 @@ class SocialManager extends UserManager
$html .= empty($graph->description) ? '' : '<p class="description">'.$graph->description.'</p>';
$html .= '<a href="'.$link.'">'.$link.'</a>';
$html .= '</div>';
return $html;
}
@ -1746,7 +1759,7 @@ class SocialManager extends UserManager
$statusIcon = Display::span('', array('class' => 'offline_user_in_text'));
}
$friendHtml.= '<li class="">';
$friendHtml.= '<li>';
$friendHtml.= '<div>';
// the height = 92 must be the same in the image_friend_network span style in default.css

@ -86,6 +86,7 @@ class Statistics
}
$res = Database::query($sql);
$obj = Database::fetch_object($res);
return $obj->number;
}
@ -238,7 +239,9 @@ class Statistics
user.username as col5,
user.user_id as col6,
default_date as col7
FROM $track_e_default as track_default, $table_user as user, $access_url_rel_user_table as url
FROM $track_e_default as track_default,
$table_user as user,
$access_url_rel_user_table as url
WHERE
track_default.default_user_id = user.user_id AND
url.user_id = user.user_id AND

@ -197,6 +197,7 @@ class SystemAnnouncementManager
$content .= '</table>';
$content .= '</div>';
}
return $content;
}

@ -49,13 +49,12 @@ class UrlManager
{
$url_id = intval($url_id);
$table = Database :: get_main_table(TABLE_MAIN_ACCESS_URL);
$tms = time();
$sql = "UPDATE $table
SET url = '".Database::escape_string($url)."',
description = '".Database::escape_string($description)."',
active = '".intval($active)."',
created_by = '".api_get_user_id()."',
tms = FROM_UNIXTIME(".$tms.")
tms = '".api_get_utc_datetime()."'
WHERE id = '$url_id'";
$result = Database::query($sql);
@ -164,6 +163,7 @@ class UrlManager
WHERE id = ".intval($url_id);
$res = Database::query($sql);
$row = Database::fetch_array($res);
return $row;
}
@ -178,7 +178,7 @@ class UrlManager
{
$where = '';
$table_url_rel_user = Database :: get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
$tbl_user = Database :: get_main_table(TABLE_MAIN_USER);
$tbl_user = Database :: get_main_table(TABLE_MAIN_USER);
if (!empty($access_url_id)) {
$where = "WHERE $table_url_rel_user.access_url_id = ".intval($access_url_id);
}
@ -335,6 +335,7 @@ class UrlManager
$result = Database::query($sql);
$courses = Database::store_result($result, 'ASSOC');
return $courses;
}
@ -584,6 +585,7 @@ class UrlManager
course_category_id = ".intval($categoryCourseId);
$result = Database::query($sql);
$num = Database::num_rows($result);
return $num;
}
@ -643,10 +645,10 @@ class UrlManager
$count = UrlManager::relation_url_session_exist($session_id, $url_id);
if ($count == 0) {
$sql = "INSERT INTO $table_url_rel_session
SET session_id = ".intval(
$session_id
).", access_url_id = ".intval($url_id);
$sql = "INSERT INTO $table_url_rel_session
SET
session_id = ".intval($session_id).",
access_url_id = ".intval($url_id);
$result = Database::query($sql);
if ($result) {
$result_array[$url_id][$session_id] = 1;
@ -1045,8 +1047,6 @@ class UrlManager
return $url_list;
}
/**
* @param int $courseId
* @return array
@ -1064,7 +1064,6 @@ class UrlManager
return $url_list;
}
/**
* @param $session_id
* @return array
@ -1131,5 +1130,4 @@ class UrlManager
$response->addAssign('ajax_list_courses', 'innerHTML', api_utf8_encode($return));
return $response;
}
}

@ -8,7 +8,6 @@
*/
class UserApiKeyManager
{
/**
* The name of the default service.
*

@ -1345,7 +1345,11 @@ class UserGroup extends Model
$form->setRequiredNote('<span class="form_required">*</span> <small>'.get_lang('ThisFieldIsRequired').'</small>');
// Setting the form elements
$form->addButtonCreate($header);
if ($type == 'add') {
$form->addButtonCreate($header);
} else {
$form->addButtonUpdate($header);
}
}
/**

@ -8,7 +8,6 @@
*/
class MessagesWebService extends WebService
{
const SERVICE_NAME = 'MsgREST';
/**
@ -125,5 +124,4 @@ class MessagesWebService extends WebService
return $messages;
}
}

@ -8,7 +8,6 @@
*/
abstract class WebService
{
protected $apiKey;
/**

@ -15,9 +15,6 @@
* @author Thomas Depraetere, Hugues Peeters, Christophe Gesch<EFBFBD> - original versions
* @package chamilo.link
*/
/* INIT SECTION */
require_once '../inc/global.inc.php';
$this_section = SECTION_COURSES;

@ -109,7 +109,9 @@ if (isset($_GET['f']) && $_GET['f'] == 'social') {
$social_parameter = '';
if (isset($_GET['f']) && $_GET['f'] == 'social' || api_get_setting('allow_social_tool') == 'true') {
if ((isset($_GET['f']) && $_GET['f'] == 'social') ||
api_get_setting('allow_social_tool') == 'true'
) {
$social_parameter = '?f=social';
} else {
$actions = null;

@ -1,12 +1,11 @@
<?php
/* For licensing terms, see /license.txt */
/*
* Coaches reporting
* @package chamilo.reporting
*/
/**
* Code
*/
ob_start();
$cidReset = true;
@ -114,7 +113,9 @@ if (Database::num_rows($result_coachs) > 0) {
$id_coach = $coachs["id_coach"];
if (isset($_GET["id_student"])) {
$sql_infos_coach = "SELECT lastname, firstname FROM $tbl_user WHERE user_id='$id_coach'";
$sql_infos_coach = "SELECT lastname, firstname
FROM $tbl_user
WHERE user_id='$id_coach'";
$result_coachs_infos = Database::query($sql_infos_coach);
$lastname = Database::result($result_coachs_infos, 0, "lastname");
$firstname = Database::result($result_coachs_infos, 0, "firstname");
@ -123,7 +124,9 @@ if (Database::num_rows($result_coachs) > 0) {
$firstname = $coachs["firstname"];
}
$sql_connection_time = "SELECT login_date, logout_date FROM $tbl_track_login WHERE login_user_id ='$id_coach' AND logout_date <> 'null'";
$sql_connection_time = "SELECT login_date, logout_date
FROM $tbl_track_login
WHERE login_user_id ='$id_coach' AND logout_date <> 'null'";
$result_connection_time = Database::query($sql_connection_time);
$nb_seconds = 0;
@ -173,7 +176,7 @@ if (Database::num_rows($result_coachs) > 0) {
<td>'.$firstname.'</td><td>'.$lastname.'</td><td>'.$s_connection_time.'</td>
<td>
<a href="course.php?type=coach&user_id='.$id_coach.'">
'.Display::return_icon('2rightarrow.png', get_lang('Details')).'
'.Display::return_icon('2rightarrow.png', get_lang('Details')).'
</a>
</td>
<td>

@ -55,7 +55,8 @@ if (!empty($my_courses)) {
}
$t_lp = Database :: get_course_table(TABLE_LP_MAIN);
$sql_lp = "SELECT lp.name, lp.id FROM $t_lp lp WHERE c_id = $course_id AND lp.session_id = 0";
$sql_lp = "SELECT lp.name, lp.id FROM $t_lp lp
WHERE c_id = $course_id AND lp.session_id = 0";
$rs_lp = Database::query($sql_lp);
$t_lpi = Database :: get_course_table(TABLE_LP_ITEM);
$t_news = Database :: get_course_table(TABLE_ANNOUNCEMENT);

@ -5,9 +5,7 @@
* @package chamilo.reporting
* Created on 28 juil. 2006 by Elixir Interactive http://www.elixir-interactive.com
*/
/**
* Init
*/
// TODO: This file seems to be unfinished and unused.
require_once '../inc/global.inc.php';
@ -67,8 +65,4 @@ if (Database::num_rows($result_course) > 0) {
echo get_lang('NoCourse');
}
/*
FOOTER
*/
Display :: display_footer();

@ -4,6 +4,7 @@
// including necessary libraries
$language_file = array('admin', 'registration');
$cidReset = true;
require_once '../inc/global.inc.php';
$libpath = api_get_path(LIBRARY_PATH);
require_once $libpath.'fileManage.lib.php';

@ -200,8 +200,6 @@ if (api_is_drh()) {
$actionsRight = Display::url(Display::return_icon('printer.png', get_lang('Print'), array(), ICON_SIZE_MEDIUM), 'javascript: void(0);', array('onclick'=>'javascript: window.print();'));
$actionsRight .= Display::url(Display::return_icon('export_csv.png', get_lang('ExportAsCSV'), array(), ICON_SIZE_MEDIUM), api_get_self().'?export=csv&keyword='.$keyword);
$toolbar = Display::toolbarAction('toolbar-user', $content = array( 0 => $actionsLeft, 1 => $actionsRight ));
$table = new SortableTable(

@ -3274,11 +3274,11 @@ class learnpath
if ($this->get_lp_session_id() == api_get_session_id()) {
$html .= '<div id="actions_lp" class="actions_lp"><hr>';
$html .= '<div class="btn-group">';
$html .= "<a class='btn btn-sm btn-default' href='lp_controller.php?" . api_get_cidreq()."&gradebook=$gradebook&action=build&lp_id=" . $this->lp_id . "' target='_parent'>" .
$html .= "<a class='btn btn-sm btn-default' href='lp_controller.php?" . api_get_cidreq()."&gradebook=$gradebook&action=build&lp_id=" . $this->lp_id . "&isStudentView=false' target='_parent'>" .
Display::returnFontAwesomeIcon('street-view') . get_lang('Overview') . "</a>";
$html .= "<a class='btn btn-sm btn-default' href='lp_controller.php?" . api_get_cidreq()."&action=add_item&type=step&lp_id=" . $this->lp_id . "' target='_parent'>" .
$html .= "<a class='btn btn-sm btn-default' href='lp_controller.php?" . api_get_cidreq()."&action=add_item&type=step&lp_id=" . $this->lp_id . "&isStudentView=false' target='_parent'>" .
Display::returnFontAwesomeIcon('pencil') . get_lang('Edit') . "</a>";
$html .= '<a class="btn btn-sm btn-default" href="lp_controller.php?'.api_get_cidreq()."&gradebook=$gradebook&action=edit&lp_id=" . $this->lp_id.'">' .
$html .= '<a class="btn btn-sm btn-default" href="lp_controller.php?'.api_get_cidreq()."&gradebook=$gradebook&action=edit&lp_id=" . $this->lp_id.'&isStudentView=false">' .
Display::returnFontAwesomeIcon('cog') . get_lang('Settings').'</a>';
$html .= '</div>';
$html .= '</div>';
@ -5668,10 +5668,10 @@ class learnpath
)
) {
$forumIconUrl = api_get_self() . '?' . api_get_cidreq() . '&' . http_build_query([
'action' => 'dissociate_forum',
'id' => $arrLP[$i]['id'],
'lp_id' => $this->lp_id
]);
'action' => 'dissociate_forum',
'id' => $arrLP[$i]['id'],
'lp_id' => $this->lp_id
]);
$forumIcon = Display::url(
Display::return_icon('forum.png', get_lang('DissociateForumToLPItem'), [], ICON_SIZE_TINY),
$forumIconUrl,
@ -5679,10 +5679,10 @@ class learnpath
);
} else {
$forumIconUrl = api_get_self() . '?' . api_get_cidreq() . '&' . http_build_query([
'action' => 'create_forum',
'id' => $arrLP[$i]['id'],
'lp_id' => $this->lp_id
]);
'action' => 'create_forum',
'id' => $arrLP[$i]['id'],
'lp_id' => $this->lp_id
]);
$forumIcon = Display::url(
Display::return_icon('forum.png', get_lang('AssociateForumToLPItem'), [], ICON_SIZE_TINY),
$forumIconUrl,

@ -4516,7 +4516,7 @@ class learnpathItem
* @param int $currentForumId The forum ID to add the new thread
* @return int The forum thread if was created. Otherwise return false
*/
public function createForumTthread($currentForumId)
public function createForumThread($currentForumId)
{
require_once api_get_path(SYS_CODE_PATH) . '/forum/forumfunction.inc.php';

@ -695,7 +695,7 @@ switch ($action) {
$is_success = true;
}
$url = api_get_self().'?action=add_item&type=step&lp_id='.intval($_SESSION['oLP']->lp_id);
$url = api_get_self().'?action=add_item&type=step&lp_id='.intval($_SESSION['oLP']->lp_id).'&'.api_get_cidreq();
header('Location: '.$url);
exit;
} else {
@ -722,7 +722,7 @@ switch ($action) {
$_POST['description']
);
$is_success = true;
$url = api_get_self().'?action=add_item&type=step&lp_id='.intval($_SESSION['oLP']->lp_id);
$url = api_get_self().'?action=add_item&type=step&lp_id='.intval($_SESSION['oLP']->lp_id).'&'.api_get_cidreq();
header('Location: '.$url);
}
if (isset($_GET['view']) && $_GET['view'] == 'build') {
@ -1331,13 +1331,13 @@ switch ($action) {
}
if (!empty($forumId)) {
$selectedItem->createForumTthread($forumId);
$selectedItem->createForumThread($forumId);
}
}
}
}
header('Location:' . api_get_path(WEB_PATH) . api_get_self() . '?' . http_build_query([
header('Location:' . api_get_self() . '?' . http_build_query([
'action' => 'add_item',
'type' => 'step',
'lp_id' => $_SESSION['oLP']->lp_id
@ -1379,7 +1379,7 @@ switch ($action) {
}
}
header('Location:' . api_get_path(WEB_PATH) . api_get_self() . '?' . http_build_query([
header('Location:' . api_get_self() . '?' . http_build_query([
'action' => 'add_item',
'type' => 'step',
'lp_id' => $_SESSION['oLP']->lp_id

@ -273,7 +273,7 @@ class scorm extends learnpath
*
* @return bool Returns -1 on error
*/
public function import_manifest($courseCode, $userMaxScore = 1, $sessionId = 0)
public function import_manifest($courseCode, $userMaxScore = 1, $sessionId = 0, $userId = 0)
{
if ($this->debug > 0) {
error_log('New LP - Entered import_manifest('.$courseCode.')', 0);
@ -281,6 +281,12 @@ class scorm extends learnpath
$courseInfo = api_get_course_info($courseCode);
$courseId = $courseInfo['real_id'];
if (empty($userId)) {
$userId = api_get_user_id();
} else {
$userId = intval($userId);
}
// Get table names.
$new_lp = Database::get_course_table(TABLE_LP_MAIN);
$new_lp_item = Database::get_course_table(TABLE_LP_ITEM);
@ -322,7 +328,7 @@ class scorm extends learnpath
TOOL_LEARNPATH,
$this->lp_id,
'LearnpathAdded',
api_get_user_id()
$userId
);
api_item_property_update(
@ -330,7 +336,7 @@ class scorm extends learnpath
TOOL_LEARNPATH,
$this->lp_id,
'visible',
api_get_user_id()
$userId
);
}

@ -15,6 +15,7 @@ api_block_anonymous_users();
if (api_get_setting('allow_social_tool') !='true') {
api_not_allowed();
}
$join_url = '';
$this_section = SECTION_SOCIAL;
$allowed_views = array('mygroups','newest','pop');

@ -33,8 +33,10 @@ $tpl->assign('allowDrhSkillsManagement', api_get_setting('allow_hr_skills_manage
if ($isStudent) {
$sql = "SELECT s.name, sru.acquired_skill_at, c.title, c.directory
FROM $skillTable s
INNER JOIN $skillRelUserTable sru ON s.id = sru.skill_id
INNER JOIN $courseTable c ON sru.course_id = c.id
INNER JOIN $skillRelUserTable sru
ON s.id = sru.skill_id
INNER JOIN $courseTable c
ON sru.course_id = c.id
WHERE sru.user_id = $userId";
$result = Database::query($sql);
@ -76,8 +78,10 @@ if ($isStudent) {
if ($selectedStudent > 0) {
$sql = "SELECT s.name, sru.acquired_skill_at, c.title, c.directory
FROM $skillTable s
INNER JOIN $skillRelUserTable sru ON s.id = sru.skill_id
INNER JOIN $courseTable c ON sru.course_id = c.id
INNER JOIN $skillRelUserTable sru
ON s.id = sru.skill_id
INNER JOIN $courseTable c
ON sru.course_id = c.id
WHERE sru.user_id = $selectedStudent
";

@ -296,9 +296,7 @@ function WSGetPortalListFromUser($params)
return $result;
}
// Course
// Course ws
$server->wsdl->addComplexType(
'getPortalListFromCourse',
'complexType',
@ -307,7 +305,8 @@ $server->wsdl->addComplexType(
'',
array(
'secret_key' => array('name' => 'secret_key', 'type' => 'xsd:string'),
'course_id' => array('name' => 'course_id', 'type' => 'xsd:string'),
'original_course_id_name' => array('name' => 'original_course_id_name', 'type' => 'xsd:string'),
'original_course_id_value' => array('name' => 'original_course_id_value', 'type' => 'xsd:string')
)
);
@ -329,7 +328,12 @@ function WSGetPortalListFromCourse($params)
return return_error(WS_ERROR_SECRET_KEY);
}
$courseId = $params['course_id'];
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$params['original_course_id_value'],
$params['original_course_id_name']
);
$courseId = $courseInfo['real_id'];
$result = UrlManager::get_access_url_from_course($courseId);
@ -351,7 +355,8 @@ $server->wsdl->addComplexType(
array(
'secret_key' => array('name' => 'secret_key', 'type' => 'xsd:string'),
'portal_id' => array('name' => 'portal_id', 'type' => 'xsd:string'),
'course_id' => array('name' => 'course_id', 'type' => 'xsd:string')
'original_course_id_name' => array('name' => 'original_course_id_name', 'type' => 'xsd:string'),
'original_course_id_value' => array('name' => 'original_course_id_value', 'type' => 'xsd:string')
)
);
@ -373,7 +378,12 @@ function WSAddCourseToPortal($params)
return return_error(WS_ERROR_SECRET_KEY);
}
$courseId = $params['course_id'];
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$params['original_course_id_value'],
$params['original_course_id_name']
);
$courseId = $courseInfo['real_id'];
$portalId = $params['portal_id'];
UrlManager::add_course_to_url($courseId, $portalId);
@ -401,7 +411,12 @@ function WSRemoveCourseFromPortal($params)
return return_error(WS_ERROR_SECRET_KEY);
}
$courseId = $params['course_id'];
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$params['original_course_id_value'],
$params['original_course_id_name']
);
$courseId = $courseInfo['real_id'];
$portalId = $params['portal_id'];
UrlManager::delete_url_rel_course($courseId, $portalId);

@ -19,7 +19,7 @@ $libpath = api_get_path(LIBRARY_PATH);
// Create the client instance
$url = api_get_path(WEB_CODE_PATH)."webservices/registration.soap.php?wsdl";
$url = api_get_path(WEB_CODE_PATH)."webservices/access_url.php?wsdl";
//$url = api_get_path(WEB_CODE_PATH)."webservices/access_url.php?wsdl";
global $_configuration;
// see the main/inc/configuration.php file to get this value
@ -36,16 +36,17 @@ if (!empty($soap_error)) {
$error_message = 'Nusoap object creation failed: ' . $soap_error;
throw new Exception($error_message);
}
$client->setDebugLevel(10000);
$client->debug_flag = true;
// This should be the IP address of the client
$ip_address = $_SERVER['SERVER_ADDR'];
$ip_address = "192.168.1.54";
$ip_address = "127.0.0.1";
//Secret key
//$secret_key = sha1($ip_address.$security_key);// Hash of the combination of IP Address + Chamilo security key
$secret_key = sha1($security_key);
$secret_key = sha1($ip_address.$security_key);// Hash of the combination of IP Address + Chamilo security key
//$secret_key = sha1($security_key);
//Creating a random user_id, this values need to be provided from your system
$random_user_id = rand(0, 1000);
@ -54,6 +55,7 @@ $generate_user_name = 'jbrion'.$random_user_id;
//Creating a password (the username)
$generate_password = sha1($generate_user_name);
$user_field = 'uid';
$sessionField = 'external_session_id';
$params = array(
'firstname' => 'Jon',
@ -86,6 +88,72 @@ $user_id = $client->call(
array('createUserPasswordCrypted' => $params)
);
// Check for an error
$err = $client->getError();
if ($err) {
// Display the error
echo '<h2>Constructor error</h2><pre>' . $err . '</pre>';
}
$sessionValueRandom = uniqid();
$params = [
'sessions' => [
[
'name' => 'session from ws: '.$sessionValueRandom,
'year_start' => '2015',
'month_start' => '10',
'day_start' => '1',
'year_end' => '',
'month_end' => '',
'day_end' => '',
'nb_days_access_before' => 0,
'nb_days_access_after' => 0,
'nolimit' => 1,
'user_id' => 1,
'original_session_id_name' => $sessionField,
'original_session_id_value' => $sessionValueRandom,
'extra' => ''
]
],
'secret_key' => $secret_key,
];
$user_id = $client->call(
'WSCreateSession',
array('createSession' => $params)
);
$data = [
'secret_key' => $secret_key,
'userssessions' => [
[
'original_user_id_name' => $user_field,
'original_session_id_value' => $sessionValueRandom,
'original_session_id_name' => $sessionField,
'original_user_id_values' => [
[
'original_user_id_value' => $random_user_id
]
]
],
],
];
$result = $client->call(
'WSSuscribeUsersToSession',
array('subscribeUsersToSession' => $data)
);
$err = $client->getError();
var_dump($result);
var_dump($err);
if (!empty($user_id) && is_numeric($user_id)) {
// 2. Get user info of the new user

@ -140,12 +140,10 @@ function WSImportLP($params)
$lpName = $params['lp_name'];
$courseCode = CourseManager::get_course_id_from_original_id(
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$courseIdValue,
$courseIdName
);
$courseInfo = api_get_course_info($courseCode);
$courseId = $courseInfo['real_id'];
if (empty($courseInfo)) {
@ -171,10 +169,11 @@ function WSImportLP($params)
$maker = 'Scorm';
$maxScore = ''; //$_REQUEST['use_max_score']
$oScorm = new scorm($courseCode);
$oScorm = new scorm($courseInfo['code']);
$fileData = base64_decode($params['file_data']);
$uniqueFile = uniqid();
$userId = 1; // admin
$filePath = api_get_path(SYS_ARCHIVE_PATH) . $uniqueFile;
file_put_contents($filePath, $fileData);
@ -199,12 +198,15 @@ function WSImportLP($params)
$oScorm->import_manifest(
$courseInfo['code'],
$maxScore,
$sessionId
$sessionId,
$userId
);
$oScorm->set_name($lpName);
$oScorm->set_proximity($proximity, $courseId);
$oScorm->set_maker($maker, $courseId);
//$oScorm->set_jslib('scorm_api.php');
if ($debug) error_log('scorm was added');
return 1;
} else {
if ($debug) error_log('manifest data empty');
@ -294,19 +296,18 @@ function WSGetLpList($params)
$sessionIdName = isset($params['session_id_name']) ? $params['session_id_name'] : null;
$sessionIdValue = isset($params['session_id_value']) ? $params['session_id_value'] : null;
$courseCode = CourseManager::get_course_id_from_original_id(
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$courseIdValue,
$courseIdName
);
$courseInfo = api_get_course_info($courseCode);
//$courseId = $courseInfo['real_id'];
if (empty($courseInfo)) {
if ($debug) error_log("Course not found: $courseIdName : $courseIdValue");
return 'Course not found';
}
$courseId = $courseInfo['real_id'];
$sessionId = 0;
if (!empty($sessionIdName) && !empty($sessionIdValue)) {
$sessionId = SessionManager::get_session_id_from_original_id(
@ -391,18 +392,17 @@ function WSDeleteLp($params)
$sessionIdName = isset($params['session_id_name']) ? $params['session_id_name'] : null;
$sessionIdValue = isset($params['session_id_value']) ? $params['session_id_value'] : null;
$courseCode = CourseManager::get_course_id_from_original_id(
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$courseIdValue,
$courseIdName
);
$courseInfo = api_get_course_info($courseCode);
$courseId = $courseInfo['real_id'];
if (empty($courseInfo)) {
if ($debug) error_log("Course not found: $courseIdName : $courseIdValue");
return 'Course not found';
}
$courseId = $courseInfo['real_id'];
$courseCode = $courseInfo['code'];
$sessionId = 0;
@ -421,7 +421,7 @@ function WSDeleteLp($params)
}
*/
$lp = new learnpath($courseInfo['code'], $lpId, null);
$lp = new learnpath($courseCode, $lpId, null);
if ($lp) {
if ($debug) error_log("LP deleted $lpId");
@ -572,20 +572,20 @@ function WSCreateLp($params)
/*$sessionIdName = isset($params['session_id_name']) ? $params['session_id_name'] : null;
$sessionIdValue = isset($params['session_id_value']) ? $params['session_id_value'] : null;*/
$courseCode = CourseManager::get_course_id_from_original_id(
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$courseIdValue,
$courseIdName
);
$courseInfo = api_get_course_info($courseCode);
$courseId = $courseInfo['real_id'];
if (empty($courseInfo)) {
if ($debug) {
error_log('Course not found');
}
}
$courseId = $courseInfo['real_id'];
$courseCode = $courseInfo['code'];
/*$sessionId = 0;
if (!empty($sessionIdName) && !empty($sessionIdValue)) {
$sessionId = SessionManager::get_session_id_from_original_id(

@ -10,7 +10,7 @@ use Chamilo\UserBundle\Entity\User;
require_once '../inc/global.inc.php';
$libpath = api_get_path(LIBRARY_PATH);
$debug = false;
$debug = true;
define('WS_ERROR_SECRET_KEY', 1);
define('WS_ERROR_NOT_FOUND_RESULT', 2);
@ -133,7 +133,8 @@ $server->wsdl->addComplexType(
'',
'SOAP-ENC:Array',
array(),
array(array('ref'=>'SOAP-ENC:arrayType','wsdl:arrayType' => 'tns:extras[]')),'tns:extras'
array(array('ref'=>'SOAP-ENC:arrayType','wsdl:arrayType' => 'tns:extras[]')),
'tns:extras'
);
$server->wsdl->addComplexType(
@ -165,7 +166,8 @@ $server->wsdl->addComplexType(
'',
'SOAP-ENC:Array',
array(),
array(array('ref'=>'SOAP-ENC:arrayType','wsdl:arrayType' => 'tns:usersParams[]')),'tns:usersParams'
array(array('ref'=>'SOAP-ENC:arrayType','wsdl:arrayType' => 'tns:usersParams[]')),
'tns:usersParams'
);
$server->wsdl->addComplexType(
@ -973,22 +975,85 @@ function WSCreateUsersPasswordCrypted($params)
//
// Prepare Input params for Subscribe Teacher to SC
$server->wsdl->addComplexType(
'SubscribeTeacherToSessionCourse',
'TeacherToSessionCourse',
'complexType',
'struct',
'all',
'',
array(
'userId' => array('name' => 'course', 'type' => 'xsd:string'), // Chamilo user Id
'sessionId' => array('name' => 'user_id', 'type' => 'xsd:string'), // Current Session course ID
'courseId' =>array('name' => 'courseId', 'type' => 'xsd:string'), // Course Real Id
'secret_key' => array('name' => 'secret_key', 'type' => 'xsd:string')
'user_id' => array('name' => 'course', 'type' => 'xsd:string'), // Chamilo user Id
'session_id' => array('name' => 'user_id', 'type' => 'xsd:string'), // Current Session course ID
'course_id' =>array('name' => 'courseId', 'type' => 'xsd:string'), // Course Real Id
'secret_key' => array('name' => 'secret_key', 'type' => 'xsd:string'),
// optional
'original_user_id_name' => array('name' => 'original_user_id_name', 'type' => 'xsd:string'),
'original_user_id_value' => array('name' => 'original_user_id_value', 'type' => 'xsd:string'),
'original_course_id_name' => array('name' => 'original_course_id_name', 'type' => 'xsd:string'),
'original_course_id_value' => array('name' => 'original_course_id_value', 'type' => 'xsd:string'),
'original_session_id_name' => array('name' => 'original_session_id_name', 'type' => 'xsd:string'),
'original_session_id_value' => array('name' => 'original_session_id_value', 'type' => 'xsd:string')
)
);
function parseCourseSessionUserParams($params)
{
global $debug;
$userId = isset($params['user_id']) ? $params['user_id'] : 0; // Chamilo user Id
$sessionId = isset($params['session_id']) ? $params['session_id'] : 0; // Current Session course ID
$courseId = isset($params['course_id']) ? $params['course_id'] : 0; // Course Real Id
if (empty($userId) && empty($sessionId) && empty($courseId)) {
// try original values
if ($debug) error_log('try original values');
$userIdName = isset($params['original_user_id_name']) ? $params['original_user_id_name'] : 0;
$userIdValue = isset($params['original_user_id_value']) ? $params['original_user_id_value'] : 0;
$courseIdName = isset($params['original_course_id_name']) ? $params['original_course_id_name'] : 0;
$courseIdValue = isset($params['original_course_id_value']) ? $params['original_course_id_value'] : 0;
$sessionIdName = isset($params['original_session_id_name']) ? $params['original_session_id_name'] : 0;
$sessionIdValue = isset($params['original_session_id_value']) ? $params['original_session_id_value'] : 0;
// Check if exits x_user_id into user_field_values table.
$userId = UserManager::get_user_id_from_original_id(
$userIdValue,
$userIdName
);
// Check whether exits $x_course_code into user_field_values table.
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$courseIdValue,
$courseIdName
);
$courseId = 0;
if ($courseInfo) {
$courseId = $courseInfo['real_id'];
}
$sessionId = SessionManager::getSessionIdFromOriginalId(
$sessionIdValue,
$sessionIdName
);
}
if ($debug) error_log('$userId found: '. $userId);
if ($debug) error_log('$courseId found: '. $courseId);
if ($debug) error_log('$sessionId found: '. $sessionId);
return [
'user_id' => $userId,
'course_id' => $courseId,
'session_id' => $sessionId,
];
}
$server->register(
'WSSubscribeTeacherToSessionCourse',
array('SubscribeTeacherToSessionCourse' => 'tns:SubscribeTeacherToSessionCourse'),
array('SubscribeTeacherToSessionCourse' => 'tns:TeacherToSessionCourse'),
array('return' => 'xsd:string'),
'urn:WSRegistration',
'urn:WSRegistration#WSSubscribeTeacherToSessionCourse',
@ -997,32 +1062,6 @@ $server->register(
'This webservice subscribe a teacher to a session course'
);
// Prepare Input params for Unsubscribe Teacher from SC
$server->wsdl->addComplexType(
'UnsubscribeTeacherFromSessionCourse',
'complexType',
'struct',
'all',
'',
array(
'userId' => array('name' => 'course', 'type' => 'xsd:string'), // Chamilo user Id
'sessionId' => array('name' => 'user_id', 'type' => 'xsd:string'), // Current Session course ID
'courseId' =>array('name' => 'courseId', 'type' => 'xsd:string'), // Course Real Id
'secret_key' => array('name' => 'secret_key', 'type' => 'xsd:string')
)
);
$server->register(
'WSUnsubscribeTeacherFromSessionCourse',
array('UnsubscribeTeacherFromSessionCourse' => 'tns:UnsubscribeTeacherFromSessionCourse'),
array('return' => 'xsd:string'),
'urn:WSRegistration',
'urn:WSRegistration#WSUnsubscribeTeacherFromSessionCourse',
'rpc',
'encoded',
'This webservice unsubscribe a teacher from a session course'
);
/**
* Subscribe teacher to a session course
*
@ -1040,13 +1079,26 @@ function WSSubscribeTeacherToSessionCourse($params)
return return_error(WS_ERROR_SECRET_KEY);
}
$userId = $params['userId']; // Chamilo user Id
$sessionId = $params['sessionId']; // Current Session course ID
$courseId = $params['courseId']; // Course Real Id
$params = parseCourseSessionUserParams($params);
$userId = $params['user_id'];
$courseId = $params['course_id'];
$sessionId = $params['session_id'];
return (SessionManager::set_coach_to_course_session($userId, $sessionId, $courseId));
return intval(SessionManager::set_coach_to_course_session($userId, $sessionId, $courseId));
}
$server->register(
'WSUnsubscribeTeacherFromSessionCourse',
array('UnsubscribeTeacherFromSessionCourse' => 'tns:TeacherToSessionCourse'),
array('return' => 'xsd:string'),
'urn:WSRegistration',
'urn:WSRegistration#WSUnsubscribeTeacherFromSessionCourse',
'rpc',
'encoded',
'This webservice unsubscribe a teacher from a session course'
);
/**
* Subscribe teacher to a session course
*
@ -1064,15 +1116,15 @@ function WSUnsubscribeTeacherFromSessionCourse($params)
return return_error(WS_ERROR_SECRET_KEY);
}
$userId = $params['userId']; // Chamilo user Id
$sessionId = $params['sessionId']; // Current Session course ID
$courseId = $params['courseId']; // Course Real Id
$params = parseCourseSessionUserParams($params);
return (SessionManager::removeUsersFromCourseSession($userId, $sessionId, $courseId));
$userId = $params['user_id'];
$courseId = $params['course_id'];
$sessionId = $params['session_id'];
return intval(SessionManager::removeUsersFromCourseSession($userId, $sessionId, $courseId));
}
/* Register WSCreateUserPasswordCrypted function */
// Register the data structures used by the service
@ -3320,15 +3372,11 @@ $server->register('WSCourseDescription', // method name
// Define the method WSCourseDescription
function WSCourseDescription($params)
{
global $_course;
if (!WSHelperVerifyKey($params)) {
return return_error(WS_ERROR_SECRET_KEY);
}
$course_table = Database::get_main_table(TABLE_MAIN_COURSE);
$array_course_desc_id = array();
$array_course__desc_default_title = array();
$array_course_desc_title = array();
$array_course_desc_content = array();
@ -3704,7 +3752,7 @@ $server->wsdl->addComplexType(
'SOAP-ENC:Array',
array(),
array(array('ref' => 'SOAP-ENC:arrayType', 'wsdl:arrayType' => 'tns:createSessionParam[]')),
'tns:createSessionParam'
'tns:createSessionParamList'
);
// Register the data structures used by the service
@ -3759,14 +3807,15 @@ $server->register('WSCreateSession', // method name
// define the method WSCreateSession
function WSCreateSession($params)
{
global $_user;
global $debug;
$sessionAdminId = 1;
if (!WSHelperVerifyKey($params)) {
return return_error(WS_ERROR_SECRET_KEY);
}
$tbl_user = Database::get_main_table(TABLE_MAIN_USER);
$tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
error_log(print_r($params, 1));
$sessions_params = $params['sessions'];
$results = array();
@ -3788,19 +3837,22 @@ function WSCreateSession($params)
$original_session_id_name = $session_param['original_session_id_name'];
$original_session_id_value = $session_param['original_session_id_value'];
$orig_session_id_value[] = $session_param['original_session_id_value'];
$extra_list = $session_param['extra'];
$extra_list = isset($session_param['extra']) ? $session_param['extra'] : '';
$sessionId = SessionManager::getSessionIdFromOriginalId(
$original_session_id_value,
$original_session_id_name
);
if (empty($sessionId)) {
if (!empty($sessionId)) {
if ($debug) {
error_log("session with external session id '$original_session_id_value' with '$name' exists");
}
$results[] = 0;
continue;
}
if (empty($nolimit)){
if (empty($nolimit)) {
$date_start = "$year_start-".(($month_start < 10)?"0$month_start":$month_start)."-".(($day_start < 10)?"0$day_start":$day_start) . ' 00:00:00';
$date_end = "$year_end-".(($month_end < 10)?"0$month_end":$month_end)."-".(($day_end < 10)?"0$day_end":$day_end) . ' 23:59:59';
} else {
@ -3809,38 +3861,60 @@ function WSCreateSession($params)
}
if (empty($name)) {
if ($debug) {
error_log("session has no name");
}
$results[] = 0;
continue;
} elseif (empty($nolimit) && (!$month_start || !$day_start || !$year_start || !checkdate($month_start, $day_start, $year_start))) {
if ($debug) {
error_log("There's an error with the start date: $month_start - $day_start - $year_start");
}
$results[] = 0;
continue;
} elseif (empty($nolimit) && (!$month_end || !$day_end || !$year_end || !checkdate($month_end,$day_end,$year_end))) {
} elseif (empty($nolimit) && (!$month_end || !$day_end || !$year_end || !checkdate($month_end, $day_end, $year_end))) {
$results[] = 0;
if ($debug) {
error_log("There's an error with the end date: $month_end - $day_end - $year_end");
}
continue;
} elseif (empty($nolimit) && $date_start >= $date_end) {
$results[] = 0;
if ($debug) {
error_log("There's an error with the start and end date");
}
continue;
} else {
$rs = Database::query("SELECT 1 FROM $tbl_session WHERE name='".addslashes($name)."'");
if (Database::num_rows($rs)) {
if ($debug) {
error_log("Session with name '$name' already exists");
}
$results[] = 0;
continue;
} else {
$startDate = new DateTime($date_start);
$endDate = new DateTime($date_end);
$diffStart = new DateInterval($nb_days_access_before);
$diffEnd = new DateInterval($nb_days_access_after);
$coachStartDate = $startDate->sub($diffStart);
$coachEndDate = $endDate->add($diffEnd);
$coachStartDate = '';
if ($date_start) {
$startDate = new DateTime($date_start);
$diffStart = new DateInterval("P".$nb_days_access_before."D");
$coachStartDate = $startDate->sub($diffStart);
$coachStartDate = $coachStartDate->format('Y-m-d H:i:s');
}
$coachEndDate = '';
if ($date_end) {
$endDate = new DateTime($date_end);
$diffEnd = new DateInterval("P".$nb_days_access_after."D");
$coachEndDate = $endDate->add($diffEnd);
$coachEndDate = $coachEndDate->format('Y-m-d H:i:s');
}
$id_session = SessionManager::create_session(
$name,
$date_start,
$date_end,
$date_start,
$date_end,
$coachStartDate->format('Y-m-d H:i:s'),
$coachEndDate->format('Y-m-d H:i:s'),
$coachStartDate,
$coachEndDate,
$id_coach,
0,
0,
@ -3849,43 +3923,52 @@ function WSCreateSession($params)
null,
0,
array(),
$_user['user_id']
$sessionAdminId
);
// Save new fieldlabel into course_field table.
$field_id = SessionManager::create_session_extra_field(
$original_session_id_name,
1,
$original_session_id_name
);
if ($id_session) {
// Save the external system's id into user_field_value table.
$res = SessionManager::update_session_extra_field_value(
$id_session,
$original_session_id_name,
$original_session_id_value
);
if ($debug) {
error_log("Session created '$id_session' ");
}
// Save new fieldlabel into course_field table.
SessionManager::create_session_extra_field(
$original_session_id_name,
1,
$original_session_id_name
);
if (is_array($extra_list) && count($extra_list) > 0) {
foreach ($extra_list as $extra) {
$extra_field_name = $extra['field_name'];
$extra_field_value = $extra['field_value'];
// Save new fieldlabel into course_field table.
$field_id = SessionManager::create_session_extra_field(
$extra_field_name,
1,
$extra_field_name
);
// Save the external system's id into course_field_value table.
$res = SessionManager::update_session_extra_field_value(
$id_session,
$extra_field_name,
$extra_field_value
);
// Save the external system's id into user_field_value table.
SessionManager::update_session_extra_field_value(
$id_session,
$original_session_id_name,
$original_session_id_value
);
if (is_array($extra_list) && count($extra_list) > 0) {
foreach ($extra_list as $extra) {
$extra_field_name = $extra['field_name'];
$extra_field_value = $extra['field_value'];
// Save new fieldlabel into course_field table.
SessionManager::create_session_extra_field(
$extra_field_name,
1,
$extra_field_name
);
// Save the external system's id into course_field_value table.
SessionManager::update_session_extra_field_value(
$id_session,
$extra_field_name,
$extra_field_value
);
}
}
$results[] = $id_session;
} else {
if ($debug) {
error_log("There was an error when trying to save session with name $name");
}
}
$results[] = $id_session;
continue;
}
}
} // end principal foreach
@ -4052,13 +4135,20 @@ function WSEditSession($params)
$results[] = 0; //StartDateShouldBeBeforeEndDate
continue;
} else {
$startDate = new DateTime($date_start);
$endDate = new DateTime($date_end);
$diffStart = new DateInterval($nb_days_access_before);
$diffEnd = new DateInterval($nb_days_access_after);
$coachStartDate = $startDate->sub($diffStart);
$coachEndDate = $endDate->add($diffEnd);
$coachStartDate = '';
if ($date_start) {
$startDate = new DateTime($date_start);
$diffStart = new DateInterval("P".$nb_days_access_before."D");
$coachStartDate = $startDate->sub($diffStart);
$coachStartDate = $coachStartDate->format('Y-m-d H:i:s');
}
$coachEndDate = '';
if ($date_end) {
$endDate = new DateTime($date_end);
$diffEnd = new DateInterval("P".$nb_days_access_after."D");
$coachEndDate = $endDate->add($diffEnd);
$coachEndDate = $coachEndDate->format('Y-m-d H:i:s');
}
$sessionInfo = api_get_session_info($id);
SessionManager::edit_session(
@ -4068,8 +4158,8 @@ function WSEditSession($params)
$date_end,
$date_start,
$date_end,
$coachStartDate->format('Y-m-d H:i:s'),
$coachEndDate->format('Y-m-d H:i:s'),
$coachStartDate,
$coachEndDate,
$id_coach,
$sessionInfo['session_category_id'],
$sessionInfo['visibility'],
@ -4085,7 +4175,7 @@ function WSEditSession($params)
$extra_field_name = $extra['field_name'];
$extra_field_value = $extra['field_value'];
// Save the external system's id into session_field_value table.
$res = SessionManager::update_session_extra_field_value(
SessionManager::update_session_extra_field_value(
$id,
$extra_field_name,
$extra_field_value
@ -4112,32 +4202,6 @@ function WSEditSession($params)
}
/* Register WSSubscribeUserToCourse function */
// Register the data structures used by the service
$server->wsdl->addComplexType(
'originalUsersList',
'complexType',
'array',
'',
'SOAP-ENC:Array',
array(),
array(array('ref' => 'SOAP-ENC:arrayType', 'wsdl:arrayType' => 'tns:deleteSessionParams[]')),
'tns:originalUsersList'
);
$server->wsdl->addComplexType(
'subscribeUserToCourseParams',
'complexType',
'struct',
'all',
'',
array(
'original_user_id_values' => array('name' => 'original_user_id_values', 'type' => 'tns:originalUsersList'),
'original_user_id_name' => array('name' => 'original_user_id_name', 'type' => 'xsd:string'),
'original_course_id_value' => array('name' => 'original_course_id_value', 'type' => 'xsd:string'),
'original_course_id_name' => array('name' => 'original_course_id_value', 'type' => 'xsd:string')
)
);
/* Register WSDeleteSession function */
$server->wsdl->addComplexType(
@ -4388,11 +4452,13 @@ function WSSubscribeUserToCourse($params) {
$resultValue = 0;
} else {
// User was found
$courseCode = CourseManager::get_course_id_from_original_id(
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$original_course_id['original_course_id_value'],
$original_course_id['original_course_id_name']
);
$courseCode = $courseInfo['code'];
if (empty($courseCode)) {
// Course was not found
$resultValue = 0;
@ -4841,11 +4907,13 @@ function WSUnSubscribeUserFromCourseSimple($params)
error_log("Course $original_course_id_value, $original_course_id_name found");
}
$courseCode = CourseManager::get_course_id_from_original_id(
$courseInfo = CourseManager::getCourseInfoFromOriginalId(
$original_course_id_value,
$original_course_id_name
);
$courseCode = $courseInfo['code'];
if (empty($courseCode)) {
// Course was not found
if ($debug) {
@ -4867,70 +4935,113 @@ function WSUnSubscribeUserFromCourseSimple($params)
return $result;
}
/* Register WSSuscribeUsersToSession function */
// Register the data structures used by the service
$server->wsdl->addComplexType(
'subscribeUsersToSessionParams',
'subscribeUserToCourseParams',
'complexType',
'struct',
'all',
'',
array(
'original_user_id_values' => array('name' => 'original_user_id_values', 'type' => 'tns:originalUsersList'),
'original_user_id_name' => array('name' => 'original_user_id_name', 'type' => 'xsd:string'),
'original_user_id_values' => array('name' => 'original_user_id_values', 'type' => 'tns:originalUsersList'),
'original_user_id_name' => array('name' => 'original_user_id_name', 'type' => 'xsd:string'),
'original_course_id_value' => array('name' => 'original_course_id_value', 'type' => 'xsd:string'),
'original_course_id_name' => array('name' => 'original_course_id_value', 'type' => 'xsd:string')
)
);
// Prepare output params, in this case will return an array.
$server->wsdl->addComplexType(
'result_subscribeUsersToSession',
'complexType',
'struct',
'all',
'',
array(
'original_user_id_values' => array('name' => 'original_user_id_values', 'type' => 'xsd:string'),
'original_session_id_value' => array('name' => 'original_session_id_value', 'type' => 'xsd:string'),
'original_session_id_name' => array('name' => 'original_session_id_name', 'type' => 'xsd:string')
'result' => array('name' => 'result', 'type' => 'xsd:string')
)
);
$server->wsdl->addComplexType(
'subscribeUsersToSessionParamsList',
'results_subscribeUsersToSession',
'complexType',
'array',
'',
'SOAP-ENC:Array',
array(),
array(array('ref' => 'SOAP-ENC:arrayType', 'wsdl:arrayType' => 'tns:subscribeUsersToSessionParams[]')),
'tns:subscribeUsersToSessionParams'
array(array('ref' => 'SOAP-ENC:arrayType', 'wsdl:arrayType' => 'tns:result_subscribeUsersToSession[]')),
'tns:result_subscribeUsersToSession'
);
$server->wsdl->addComplexType(
'subscribeUsersToSession',
'originalUserItem',
'complexType',
'struct',
'all',
'',
array(
'userssessions' => array('name' => 'userssessions', 'type' => 'tns:subscribeUsersToSessionParamsList'),
'secret_key' => array('name' => 'secret_key', 'type' => 'xsd:string')
'original_user_id_value' => array('name' => 'original_user_id_value', 'type' => 'xsd:string')
)
);
// Prepare output params, in this case will return an array.
// Register the data structures used by the service
$server->wsdl->addComplexType(
'result_subscribeUsersToSession',
'originalUsersList',
'complexType',
'array',
'',
'SOAP-ENC:Array',
array(),
array(array('ref' => 'SOAP-ENC:arrayType', 'wsdl:arrayType' => 'tns:originalUserItem[]')),
'tns:originalUserItem'
);
/* Register WSSuscribeUsersToSession function */
// Register the data structures used by the service
$server->wsdl->addComplexType(
'subscribeUsersToSessionParams',
'complexType',
'struct',
'all',
'',
array(
'original_user_id_values' => array('name' => 'original_user_id_values', 'type' => 'xsd:string'),
'original_user_id_values' => array('name' => 'original_user_id_values', 'type' => 'tns:originalUsersList'),
'original_user_id_name' => array('name' => 'original_user_id_name', 'type' => 'xsd:string'),
'original_session_id_value' => array('name' => 'original_session_id_value', 'type' => 'xsd:string'),
'result' => array('name' => 'result', 'type' => 'xsd:string')
'original_session_id_name' => array('name' => 'original_session_id_name', 'type' => 'xsd:string')
)
);
$server->wsdl->addComplexType(
'results_subscribeUsersToSession',
'subscribeUsersToSessionParamsList',
'complexType',
'array',
'',
'SOAP-ENC:Array',
array(),
array(array('ref' => 'SOAP-ENC:arrayType', 'wsdl:arrayType' => 'tns:result_subscribeUsersToSession[]')),
'tns:result_subscribeUsersToSession'
array(array('ref' => 'SOAP-ENC:arrayType', 'wsdl:arrayType' => 'tns:subscribeUsersToSessionParams[]')),
'tns:subscribeUsersToSessionParams'
);
$server->wsdl->addComplexType(
'subscribeUsersToSession',
'complexType',
'struct',
'all',
'',
array(
'userssessions' => array('name' => 'userssessions', 'type' => 'tns:subscribeUsersToSessionParamsList'),
'secret_key' => array('name' => 'secret_key', 'type' => 'xsd:string')
)
);
// Register the method to expose
$server->register('WSSuscribeUsersToSession', // method name
array('subscribeUsersToSession' => 'tns:subscribeUsersToSession'), // input parameters
@ -4945,10 +5056,10 @@ $server->register('WSSuscribeUsersToSession', // method
// define the method WSSuscribeUsersToSession
function WSSuscribeUsersToSession($params)
{
global $debug;
if (!WSHelperVerifyKey($params)) {
return return_error(WS_ERROR_SECRET_KEY);
}
$user_table = Database::get_main_table(TABLE_MAIN_USER);
$tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
$tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
@ -4956,11 +5067,14 @@ function WSSuscribeUsersToSession($params)
$tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
$userssessions_params = $params['userssessions'];
if ($debug) {
error_log(print_r($params, 1));
}
$results = array();
$orig_user_id_value = array();
$orig_session_id_value = array();
foreach ($userssessions_params as $usersession_params) {
$original_session_id_value = $usersession_params['original_session_id_value'];
$original_session_id_name = $usersession_params['original_session_id_name'];
$original_user_id_name = $usersession_params['original_user_id_name'];
@ -4980,9 +5094,14 @@ function WSSuscribeUsersToSession($params)
$usersList = array();
foreach ($original_user_id_values as $key => $row_original_user_list) {
$user_id = UserManager::get_user_id_from_original_id(
$original_user_id_values[$key],
$original_user_id_name[$key]
$row_original_user_list['original_user_id_value'],
$original_user_id_name
);
if ($debug) {
error_log(" User to subscribe: $user_id");
}
if ($user_id == 0) {
continue; // user_id doesn't exist.
} else {
@ -6035,9 +6154,9 @@ function WSUpdateUserApiKey($params) {
$info = api_get_user_info_from_username($params['chamilo_username']);
$user_id = $info['user_id'];
// Save new fieldlabel into user_field table.
$field_id = UserManager::create_extra_field($params['original_user_id_name'], 1, $params['original_user_id_name'], '');
UserManager::create_extra_field($params['original_user_id_name'], 1, $params['original_user_id_name'], '');
// Save the external system's id into user_field_value table.
$res = UserManager::update_extra_field_value($user_id, $params['original_user_id_name'], $params['original_user_id_value']);
UserManager::update_extra_field_value($user_id, $params['original_user_id_name'], $params['original_user_id_value']);
}
else {
return 0;
@ -6185,7 +6304,7 @@ $server->register('WSUserSubscribedInCourse', // meth
* @param array $params Array of parameters (course and user_id)
* @return bool|null|soap_fault A simple boolean (true if user is subscribed, false otherwise)
*/
function WSUserSubscribedInCourse ($params)
function WSUserSubscribedInCourse($params)
{
global $debug;

@ -54,9 +54,9 @@ class AllowIframes extends HTMLPurifier_Filter
protected function postFilterCallback($matches)
{
// Domain Whitelist
$youTubeMatch = preg_match('#src="(https:)?//www.youtube(-nocookie)?.com/#i', $matches[1]);
$vimeoMatch = preg_match('#src="http://player.vimeo.com/#i', $matches[1]);
$googleMapsMatch = preg_match('#src="https://maps.google.com/#i', $matches[1]);
$youTubeMatch = preg_match('#src="(https:)?//www.youtube(-nocookie)?.com/#i', $matches[1]);
$vimeoMatch = preg_match('#://player.vimeo.com/#i', $matches[1]);
$googleMapsMatch = preg_match('#src="https://maps.google.com/#i', $matches[1]);
if ($youTubeMatch || $vimeoMatch || $googleMapsMatch) {
$extra = ' frameborder="0"';

Loading…
Cancel
Save