ILIAS  release_4-3 Revision
 All Data Structures Namespaces Files Functions Variables Groups Pages
ilLPStatusPlugin Class Reference
+ Inheritance diagram for ilLPStatusPlugin:
+ Collaboration diagram for ilLPStatusPlugin:

Public Member Functions

 _getNotAttempted ($a_obj_id)
 _getInProgress ($a_obj_id)
 _getCompleted ($a_obj_id)
 _getFailed ($a_obj_id)
 determineStatus ($a_obj_id, $a_user_id, $a_obj=null)
 Determine status.
 determinePercentage ($a_obj_id, $a_user_id, $a_obj=null)
 Determine percentage.
- Public Member Functions inherited from ilLPStatus
 ilLPStatus ($a_obj_id)
 _getCountNotAttempted ($a_obj_id)
 _getCountInProgress ($a_obj_id)
 _getCountCompleted ($a_obj_id)
 _getCountFailed ()
 _getStatusInfo ($a_obj_id)
 _getTypicalLearningTime ($a_obj_id)
 _updateStatus ($a_obj_id, $a_usr_id, $a_obj=null, $a_percentage=false, $a_no_raise=false)
 New status handling (st: status, nr: accesses, p: percentage, t: time spent, m: mark)
 refreshStatus ($a_obj_id, $a_users=null)
 Refresh status.
 _lookupStatus ($a_obj_id, $a_user_id)
 Lookup status.
 _lookupStatusChanged ($a_obj_id, $a_user_id)
 Lookup status changed.

Data Fields

const INACTIVE_PLUGIN = -1
- Data Fields inherited from ilLPStatus
 $obj_id = null
 $db = null

Static Protected Member Functions

static initPluginObj ($a_obj_id)
 Get ilObjectPlugin for object id.
static getLPStatusData ($a_obj_id, $a_status)
 Read existing LP status data.
static getLPDataForUser ($a_obj_id, $a_user_id)
 Read existing LP status data for user.
static getPercentageForUser ($a_obj_id, $a_user_id)
- Static Protected Member Functions inherited from ilLPStatus
static _lookupStatusForObject ($a_obj_id, $a_status, $a_user_ids=null)
 Get users with given status for object.

Static Protected Attributes

static $plugins

Additional Inherited Members

- Static Public Member Functions inherited from ilLPStatus
static checkStatusForObject ($a_obj_id, $a_users=false)
 This function checks whether the status for a given number of users is dirty and must be recalculated.
static writeStatus ($a_obj_id, $a_user_id, $a_status, $a_percentage=false, $a_force_per=false)
 Write status for user and object.
static setInProgressIfNotAttempted ($a_obj_id, $a_user_id)
 This function shoudl be clalled for normal "read events".
static setAllDirty ()
 Sets all status to dirty.
static setDirty ($a_obj_id)
 Sets status of an object to dirty.
static _lookupCompletedForObject ($a_obj_id, $a_user_ids=null)
 Get completed users for object.
static _lookupFailedForObject ($a_obj_id, $a_user_ids=null)
 Get failed users for object.
static _lookupInProgressForObject ($a_obj_id, $a_user_ids=null)
 Get in progress users for object.
- Protected Member Functions inherited from ilLPStatus
 raiseEvent ($a_obj_id, $a_usr_id, $a_status, $a_percentage)

Detailed Description

Definition at line 13 of file class.ilLPStatusPlugin.php.

Member Function Documentation

ilLPStatusPlugin::_getCompleted (   $a_obj_id)

Reimplemented from ilLPStatus.

Definition at line 87 of file class.ilLPStatusPlugin.php.

References getLPStatusData(), initPluginObj(), and LP_STATUS_COMPLETED_NUM.

{
$plugin = self::initPluginObj($a_obj_id);
if($plugin)
{
if($plugin !== self::INACTIVE_PLUGIN)
{
return (array)$plugin->getLPCompleted();
}
else
{
// re-use existing data for inactive plugin
}
}
return array();
}

+ Here is the call graph for this function:

ilLPStatusPlugin::_getFailed (   $a_obj_id)

Reimplemented from ilLPStatus.

Definition at line 105 of file class.ilLPStatusPlugin.php.

References getLPStatusData(), initPluginObj(), and LP_STATUS_FAILED_NUM.

{
$plugin = self::initPluginObj($a_obj_id);
if($plugin)
{
if($plugin !== self::INACTIVE_PLUGIN)
{
return (array)$plugin->getLPFailed();
}
else
{
// re-use existing data for inactive plugin
}
}
return array();
}

+ Here is the call graph for this function:

ilLPStatusPlugin::_getInProgress (   $a_obj_id)

Reimplemented from ilLPStatus.

Definition at line 69 of file class.ilLPStatusPlugin.php.

References getLPStatusData(), initPluginObj(), and LP_STATUS_IN_PROGRESS_NUM.

{
$plugin = self::initPluginObj($a_obj_id);
if($plugin)
{
if($plugin !== self::INACTIVE_PLUGIN)
{
return (array)$plugin->getLPInProgress();
}
else
{
// re-use existing data for inactive plugin
}
}
return array();
}

+ Here is the call graph for this function:

ilLPStatusPlugin::_getNotAttempted (   $a_obj_id)

Reimplemented from ilLPStatus.

Definition at line 51 of file class.ilLPStatusPlugin.php.

References getLPStatusData(), initPluginObj(), and LP_STATUS_NOT_ATTEMPTED_NUM.

{
$plugin = self::initPluginObj($a_obj_id);
if($plugin)
{
if($plugin !== self::INACTIVE_PLUGIN)
{
return (array)$plugin->getLPNotAttempted();
}
else
{
// re-use existing data for inactive plugin
}
}
return array();
}

+ Here is the call graph for this function:

ilLPStatusPlugin::determinePercentage (   $a_obj_id,
  $a_usr_id,
  $a_obj = null 
)

Determine percentage.

Parameters
@return

Reimplemented from ilLPStatus.

Definition at line 143 of file class.ilLPStatusPlugin.php.

References getPercentageForUser(), and initPluginObj().

{
$plugin = self::initPluginObj($a_obj_id);
if($plugin)
{
if($plugin !== self::INACTIVE_PLUGIN)
{
if (method_exists($plugin, "getPercentageForUser"))
{
return $plugin->getPercentageForUser($a_user_id);
}
}
// re-use existing data for inactive plugin
return self::getPercentageForUser($a_obj_id, $a_user_id);
}
// #11368
return 0;
}

+ Here is the call graph for this function:

ilLPStatusPlugin::determineStatus (   $a_obj_id,
  $a_usr_id,
  $a_obj = null 
)

Determine status.

Parameters
@return

Reimplemented from ilLPStatus.

Definition at line 123 of file class.ilLPStatusPlugin.php.

References getLPDataForUser(), initPluginObj(), and LP_STATUS_NOT_ATTEMPTED_NUM.

{
$plugin = self::initPluginObj($a_obj_id);
if($plugin)
{
if($plugin !== self::INACTIVE_PLUGIN)
{
// :TODO: create read_event here to make sure?
return $plugin->getLPStatusForUser($a_user_id);
}
else
{
// re-use existing data for inactive plugin
return self::getLPDataForUser($a_obj_id, $a_user_id);
}
}
// #11368
}

+ Here is the call graph for this function:

static ilLPStatusPlugin::getLPDataForUser (   $a_obj_id,
  $a_user_id 
)
staticprotected

Read existing LP status data for user.

Parameters
int$a_obj_id
int$a_user_id
Returns
int

Definition at line 193 of file class.ilLPStatusPlugin.php.

References $row, and LP_STATUS_NOT_ATTEMPTED_NUM.

Referenced by determineStatus().

{
global $ilDB;
$set = $ilDB->query("SELECT status".
" FROM ut_lp_marks".
" WHERE obj_id = ".$ilDB->quote($a_obj_id, "integer").
" AND usr_id = ".$ilDB->quote($a_user_id, "integer"));
$row = $ilDB->fetchAssoc($set);
$status = $row["status"];
if(!$status)
{
}
return $status;
}

+ Here is the caller graph for this function:

static ilLPStatusPlugin::getLPStatusData (   $a_obj_id,
  $a_status 
)
staticprotected

Read existing LP status data.

Parameters
int$a_obj_id
int$a_status
Returns
array user ids

Definition at line 169 of file class.ilLPStatusPlugin.php.

References $row.

Referenced by _getCompleted(), _getFailed(), _getInProgress(), and _getNotAttempted().

{
global $ilDB;
$all = array();
$set = $ilDB->query("SELECT usr_id".
" FROM ut_lp_marks".
" WHERE obj_id = ".$ilDB->quote($a_obj_id, "integer").
" AND status = ".$ilDB->quote($a_status, "integer"));
while($row = $ilDB->fetchAssoc($set))
{
$all[] = $row["usr_id"];
}
return $all;
}

+ Here is the caller graph for this function:

static ilLPStatusPlugin::getPercentageForUser (   $a_obj_id,
  $a_user_id 
)
staticprotected

Definition at line 210 of file class.ilLPStatusPlugin.php.

References $row.

Referenced by determinePercentage().

{
global $ilDB;
$set = $ilDB->query("SELECT percentage".
" FROM ut_lp_marks".
" WHERE obj_id = ".$ilDB->quote($a_obj_id, "integer").
" AND usr_id = ".$ilDB->quote($a_user_id, "integer"));
$row = $ilDB->fetchAssoc($set);
return (int) $row["percentage"];
}

+ Here is the caller graph for this function:

static ilLPStatusPlugin::initPluginObj (   $a_obj_id)
staticprotected

Get ilObjectPlugin for object id.

Parameters
int$a_obj_id
Returns
ilObjectPlugin

Definition at line 25 of file class.ilLPStatusPlugin.php.

References ilObject\_lookupType(), ilObjectFactory\getInstanceByObjId(), INACTIVE_PLUGIN, and ilRepositoryObjectPluginSlot\isTypePluginWithLP().

Referenced by _getCompleted(), _getFailed(), _getInProgress(), _getNotAttempted(), determinePercentage(), and determineStatus().

{
if(!isset(self::$plugins[$a_obj_id]))
{
self::$plugins[$a_obj_id] = false;
// active plugin?
include_once 'Services/Repository/classes/class.ilRepositoryObjectPluginSlot.php';
{
if($obj && $obj instanceof ilLPStatusPluginInterface)
{
self::$plugins[$a_obj_id] = $obj;
}
}
// inactive plugin?
{
self::$plugins[$a_obj_id] = self::INACTIVE_PLUGIN;
}
}
return self::$plugins[$a_obj_id];
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

Field Documentation

ilLPStatusPlugin::$plugins
staticprotected

Definition at line 15 of file class.ilLPStatusPlugin.php.

const ilLPStatusPlugin::INACTIVE_PLUGIN = -1

Definition at line 17 of file class.ilLPStatusPlugin.php.

Referenced by initPluginObj().


The documentation for this class was generated from the following file: