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/main/newscorm/scormOrganization.class.php

182 lines
5.8 KiB

<?php
/* For licensing terms, see /license.txt */
/**
* Container for the scormOrganization class
* @package chamilo.learnpath.scorm
* @author Yannick Warnier <ywarnier@beeznest.org>
*/
/**
* Class defining the <organization> tag in an imsmanifest.xml file
*/
class scormOrganization {
public $identifier = '';
public $structure = '';
public $title = '';
public $items = array();
public $metadata;
/**
* Class constructor. Depending of the type of construction called ('db' or 'manifest'), will create a scormOrganization
* object from database records or from the DOM element given as parameter
* @param string Type of construction needed ('db' or 'manifest', default = 'manifest')
* @param mixed Depending on the type given, DB id for the lp_item or reference to the DOM element
*/
public function __construct($type='manifest',&$element,$scorm_charset='UTF-8') {
if (isset($element)) {
$v = substr(phpversion(),0,1);
if ($v == 4) {
switch ($type) {
case 'db':
//TODO implement this way of metadata object creation
return false;
case 'manifest': //do the same as the default
default:
//if($first_item->type == XML_ELEMENT_NODE) this is already check prior to the call to this function
$children = $element->children();
foreach ($children as $a => $dummy) {
$child =& $children[$a];
switch ($child->type) {
case XML_ELEMENT_NODE:
switch ($child->tagname) {
case 'item':
$oItem = new scormItem('manifest',$child);
if ($oItem->identifier != '') {
$this->items[$oItem->identifier] = $oItem;
}
break;
case 'metadata':
$this->metadata = new scormMetadata('manifest',$child);
break;
case 'title':
$tmp_children = $child->children();
if (count($tmp_children)==1 and $tmp_children[0]->content!='' ) {
$this->title = $tmp_children[0]->content;
}
break;
}
break;
case XML_TEXT_NODE:
break;
}
}
$attributes = $element->attributes();
//$keep_href = '';
foreach ($attributes as $a1 => $dummy) {
$attrib =& $attributes[$a1];
switch ($attrib->name) {
case 'identifier':
$this->identifier = $attrib->value;
break;
case 'structure':
$this->structure = $attrib->value;
break;
}
}
return true;
}
} elseif ($v == 5) {
//parsing using PHP5 DOMXML methods
switch($type){
case 'db':
//TODO implement this way of metadata object creation
return false;
case 'manifest': //do the same as the default
default:
//if($first_item->type == XML_ELEMENT_NODE) this is already check prior to the call to this function
$children = $element->childNodes;
foreach ($children as $child) {
switch ($child->nodeType) {
case XML_ELEMENT_NODE:
switch ($child->tagName) {
case 'item':
$oItem = new scormItem('manifest',$child);
if($oItem->identifier != ''){
$this->items[$oItem->identifier] = $oItem;
}
break;
case 'metadata':
$this->metadata = new scormMetadata('manifest',$child);
break;
case 'title':
$tmp_children = $child->childNodes;
if ($tmp_children->length==1 and $child->firstChild->nodeValue != '' ) {
$this->title = html_entity_decode(html_entity_decode($child->firstChild->nodeValue,ENT_QUOTES,$scorm_charset));
}
break;
}
break;
case XML_TEXT_NODE:
break;
}
}
if ($element->hasAttributes()) {
$attributes = $element->attributes;
//$keep_href = '';
foreach ($attributes as $attrib) {
switch ($attrib->name) {
case 'identifier':
$this->identifier = $attrib->value;
break;
case 'structure':
$this->structure = $attrib->value;
break;
}
}
}
return true;
}
} else {
//cannot parse because not PHP4 nor PHP5... We should not even be here anyway...
return false;
}
}
return false;
}
/**
* Get a flat list of items in the organization
* @return array Array containing an ordered list of all items with their level and all information related to each item
*/
public function get_flat_items_list() {
$list = array();
$i = 1;
foreach ($this->items as $id=>$dummy) {
$abs_order = 0;
$this->items[$id]->get_flat_list($list,$abs_order,$i,0); //passes the array as a pointer so it is modified in $list directly
$i++;
}
return $list;
}
/**
* Name getter
* @return string Name or empty string
*/
public function get_name() {
if (!empty($this->title)) {
return Database::escape_string($this->title);
} else {
return '';
}
}
/**
* Reference identifier getter
* @return string Identifier or empty string
*/
public function get_ref() {
if (!empty($this->identifier)) {
return Database::escape_string($this->identifier);
} else {
return '';
}
}
/**
* Sets the title element
* @param string New title to set
*/
public function set_name($title) {
if (!empty($title)) {
$this->title = Database::escape_string($title);
}
}
}
?>