ILIAS  Release_4_2_x_branch Revision 61807
 All Data Structures Namespaces Files Functions Variables Groups Pages
ilObjWiki Class Reference

Class ilObjWiki. More...

+ Inheritance diagram for ilObjWiki:
+ Collaboration diagram for ilObjWiki:

Public Member Functions

 ilObjWiki ($a_id=0, $a_call_by_reference=true)
 Constructor public.
 setOnline ($a_online)
 Set Online.
 getOnline ()
 Get Online.
 setRating ($a_rating)
 Set Enable Rating.
 getRating ()
 Get Enable Rating.
 setPublicNotes ($a_val)
 Set public notes.
 getPublicNotes ()
 Get public notes.
 setImportantPages ($a_val)
 Set important pages.
 getImportantPages ()
 Get important pages.
 setStartPage ($a_startpage)
 Set Start Page.
 getStartPage ()
 Get Start Page.
 setShortTitle ($a_shorttitle)
 Set ShortTitle.
 getShortTitle ()
 Get ShortTitle.
 setIntroduction ($a_introduction)
 Set Introduction.
 getIntroduction ()
 Get Introduction.
 getStyleSheetId ()
 get ID of assigned style sheet object
 setStyleSheetId ($a_style_id)
 set ID of assigned style sheet object
 setPageToc ($a_val)
 Set page toc.
 getPageToc ()
 Get page toc.
 create ($a_prevent_start_page_creation=false)
 Create new wiki.
 update ($a_prevent_start_page_creation=false)
 update object data
 read ()
 Read wiki data.
 delete ()
 delete object and all related data
 initDefaultRoles ()
 init default roles settings
 notify ($a_event, $a_ref_id, $a_parent_non_rbac_id, $a_node_id, $a_params=0)
 notifys an object about an event occured Based on the event happend, each object may decide how it reacts.
 addImportantPage ($a_page_id)
 Add important page.
 isImportantPage ($a_page_id)
 Is page an important page?
 removeImportantPage ($a_id)
 Remove important page.
 saveOrderingAndIndentation ($a_ord, $a_indent)
 Save ordering and indentation.
 fixImportantPagesNumbering ()
 Fix important pages numbering.
- Public Member Functions inherited from ilObject
 ilObject ($a_id=0, $a_reference=true)
 Constructor public.
 withReferences ()
 determines wehter objects are referenced or not (got ref ids or not)
 read ($a_force_db=false)
 read object data from db into object
 getId ()
 get object id public
 setId ($a_id)
 set object id public
 setRefId ($a_id)
 set reference id public
 getRefId ()
 get reference id public
 getType ()
 get object type public
 setType ($a_type)
 set object type public
 getPresentationTitle ()
 get presentation title Normally same as title Overwritten for sessions
 getTitle ()
 get object title public
 getUntranslatedTitle ()
 get untranslated object title public
 setTitle ($a_title)
 set object title
 getDescription ()
 get object description
 setDescription ($a_desc)
 set object description
 getLongDescription ()
 get object long description (stored in object_description)
 getImportId ()
 get import id
 setImportId ($a_import_id)
 set import id
 getOwner ()
 get object owner
 getOwnerName ()
 _lookupOwnerName ($a_owner_id)
 lookup owner name for owner id
 setOwner ($a_owner)
 set object owner
 getCreateDate ()
 get create date public
 getLastUpdateDate ()
 get last update date public
 getDiskUsage ()
 Gets the disk usage of the object in bytes.
 setObjDataRecord ($a_record)
 set object_data record (note: this method should only be called from the ilObjectFactory class)
 create ()
 create
 update ()
 update object in db
 MDUpdateListener ($a_element)
 Meta data update listener.
 createMetaData ()
 create meta data entry
 updateMetaData ()
 update meta data entry
 deleteMetaData ()
 delete meta data entry
 updateOwner ()
 update owner of object in db
 _getIdForImportId ($a_import_id)
 get current object id for import id (static)
 _lookupOwner ($a_id)
 lookup object owner
 _lookupLastUpdate ($a_id, $a_as_string=false)
 lookup last update
 _getLastUpdateOfObjects ($a_objs)
 Get last update for a set of media objects.
 _setDeletedDate ($a_ref_id)
 only called in ilTree::saveSubTree
 _resetDeletedDate ($a_ref_id)
 only called in ilObjectGUI::insertSavedNodes
 _lookupDeletedDate ($a_ref_id)
 only called in ilObjectGUI::insertSavedNodes
 _writeTitle ($a_obj_id, $a_title)
 write title to db (static)
 _writeDescription ($a_obj_id, $a_desc)
 write description to db (static)
 _writeImportId ($a_obj_id, $a_import_id)
 write import id to db (static)
 _isInTrash ($a_ref_id)
 checks wether object is in trash
 _hasUntrashedReference ($a_obj_id)
 checks wether an object has at least one reference that is not in trash
 _lookupObjectId ($a_ref_id)
 lookup object id
 _getObjectsDataForType ($a_type, $a_omit_trash=false)
 get all objects of a certain type
 putInTree ($a_parent_ref)
 maybe this method should be in tree object!?
 setPermissions ($a_parent_ref)
 set permissions of object
 createReference ()
 creates reference for object
 countReferences ()
 count references of object
 createRoleFolder ()
 creates a local role folder
 applyDidacticTemplate ($a_tpl_id)
 Apply template.
 setRegisterMode ($a_bool)
 isUserRegistered ($a_user_id=0)
 requireRegistration ()
 getXMLZip ()
 getHTMLDirectory ()
 cloneObject ($a_target_id, $a_copy_id=0, $a_omit_tree=false)
 Clone object permissions, put in tree ...
 appendCopyInfo ($a_target_id, $a_copy_id)
 Prepend Copy info if object with same name exists in that container.
 cloneDependencies ($a_target_id, $a_copy_id)
 Clone object dependencies.
 cloneMetaData ($target_obj)
 Copy meta data.

Static Public Member Functions

static checkShortTitleAvailability ($a_short_title)
 Check availability of short title.
static _lookupRating ($a_wiki_id)
 Lookup whether rating is activated.
static _lookupPublicNotes ($a_wiki_id)
 Lookup whether public notes are activated.
static _lookupStartPage ($a_wiki_id)
 Lookup start page.
static writeStartPage ($a_id, $a_name)
 Write start page.
static _performSearch ($a_wiki_id, $a_searchterm)
 Search in Wiki.
static _lookupImportantPages ($a_wiki_id)
 Lookup whether important pages are activated.
static _lookupImportantPagesList ($a_wiki_id)
 Get important pages list.
static _lookupMaxOrdNrImportantPages ($a_wiki_id)
 Get important pages list.
static _lookupPageToc ($a_wiki_id)
 Lookup whether important pages are activated.
- Static Public Member Functions inherited from ilObject
static _lookupObjIdByImportId ($a_import_id)
static _getAllReferences ($a_id)
 get all reference ids of object
static _lookupTitle ($a_id)
 lookup object title
static _getIdsForTitle ($title, $type= '', $partialmatch=false)
static _lookupDescription ($a_id)
 lookup object description
static _lookupObjId ($a_id)
static _lookupType ($a_id, $a_reference=false)
 lookup object type
 _exists ($a_id, $a_reference=false)
 checks if an object exists in object_data
static _getObjectsByType ($a_obj_type="", $a_owner="")
 Get objects by type.
static _prepareCloneSelection ($a_ref_ids, $new_type, $show_path=true)
 Prepare copy wizard object selection.
static _getIcon ($a_obj_id="", $a_size="big", $a_type="", $a_offline=false)
 Get icon for repository item.
static collectDeletionDependencies (&$deps, $a_ref_id, $a_obj_id, $a_type, $a_depth=0)
 Collect deletion dependencies.
static getDeletionDependencies ($a_obj_id)
 Get deletion dependencies.

Protected Attributes

 $online = false
 $public_notes = true

Static Private Member Functions

static _lookup ($a_wiki_id, $a_field)
 Lookup a data field.

Additional Inherited Members

- Data Fields inherited from ilObject
const TITLE_LENGTH = 128
 max length of object title
 $ilias
 $lng
 $id
 $ref_id
 $type
 $title
 $untranslatedTitle
 $desc
 $long_desc
 $owner
 $create_date
 $last_update
 $import_id
 $register = false
 $referenced
 $objectList
 $max_title
 $max_desc
 $add_dots
 $obj_data_record
 object_data record

Detailed Description

Class ilObjWiki.

Author
Alex Killing alex..nosp@m.kill.nosp@m.ing@g.nosp@m.mx.d.nosp@m.e
Version
$Id$

Definition at line 19 of file class.ilObjWiki.php.

Member Function Documentation

static ilObjWiki::_lookup (   $a_wiki_id,
  $a_field 
)
staticprivate

Lookup a data field.

Parameters
int$a_wiki_idWiki ID
string$a_fieldField Name
Returns
mixed field value

Definition at line 490 of file class.ilObjWiki.php.

References $ilDB, and $query.

Referenced by _lookupImportantPages(), _lookupPageToc(), _lookupPublicNotes(), _lookupRating(), and _lookupStartPage().

{
global $ilDB;
$query = "SELECT $a_field FROM il_wiki_data WHERE id = ".
$ilDB->quote($a_wiki_id, "integer");
$set = $ilDB->query($query);
$rec = $ilDB->fetchAssoc($set);
return $rec[$a_field];
}

+ Here is the caller graph for this function:

static ilObjWiki::_lookupImportantPages (   $a_wiki_id)
static

Lookup whether important pages are activated.

Parameters
int$a_wiki_idWiki ID
Returns
boolean Important pages activated?

Definition at line 578 of file class.ilObjWiki.php.

References _lookup().

{
return ilObjWiki::_lookup($a_wiki_id, "imp_pages");
}

+ Here is the call graph for this function:

static ilObjWiki::_lookupImportantPagesList (   $a_wiki_id)
static

Get important pages list.

Parameters
@return

Definition at line 589 of file class.ilObjWiki.php.

References $ilDB.

Referenced by ilImportantPagesTableGUI\__construct(), ilObjWikiGUI\editImportantPagesObject(), ilWikiImportantPagesBlockGUI\fillDataSection(), fixImportantPagesNumbering(), and saveOrderingAndIndentation().

{
global $ilDB;
$set = $ilDB->query("SELECT * FROM il_wiki_imp_pages WHERE ".
" wiki_id = ".$ilDB->quote($a_wiki_id, "integer")." ORDER BY ord ASC "
);
$imp_pages = array();
while ($rec = $ilDB->fetchAssoc($set))
{
$imp_pages[] = $rec;
}
return $imp_pages;
}

+ Here is the caller graph for this function:

static ilObjWiki::_lookupMaxOrdNrImportantPages (   $a_wiki_id)
static

Get important pages list.

Parameters
@return

Definition at line 612 of file class.ilObjWiki.php.

References $ilDB.

Referenced by addImportantPage().

{
global $ilDB;
$set = $ilDB->query("SELECT MAX(ord) as m FROM il_wiki_imp_pages WHERE ".
" wiki_id = ".$ilDB->quote($a_wiki_id, "integer")
);
$rec = $ilDB->fetchAssoc($set);
return (int) $rec["m"];
}

+ Here is the caller graph for this function:

static ilObjWiki::_lookupPageToc (   $a_wiki_id)
static

Lookup whether important pages are activated.

Parameters
int$a_wiki_idWiki ID
Returns
boolean Important pages activated?

Definition at line 787 of file class.ilObjWiki.php.

References _lookup().

Referenced by ilWikiPageGUI\__construct().

{
return ilObjWiki::_lookup($a_wiki_id, "page_toc");
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static ilObjWiki::_lookupPublicNotes (   $a_wiki_id)
static

Lookup whether public notes are activated.

Parameters
int$a_wiki_idWiki ID
Returns
boolean public notes activated?

Definition at line 477 of file class.ilObjWiki.php.

References _lookup().

Referenced by ilWikiPageGUI\addHeaderAction(), and ilWikiPageGUI\preview().

{
return ilObjWiki::_lookup($a_wiki_id, "public_notes");
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static ilObjWiki::_lookupRating (   $a_wiki_id)
static

Lookup whether rating is activated.

Parameters
int$a_wiki_idWiki ID
Returns
boolean Rating activated?

Definition at line 465 of file class.ilObjWiki.php.

References _lookup().

Referenced by ilWikiPageGUI\addHeaderAction().

{
return ilObjWiki::_lookup($a_wiki_id, "rating");
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static ilObjWiki::_lookupStartPage (   $a_wiki_id)
static

Lookup start page.

Parameters
int$a_wiki_idWiki ID
Returns
boolean Rating activated?

Definition at line 508 of file class.ilObjWiki.php.

References _lookup().

Referenced by ilWikiHandlerGUI\executeCommand(), ilWikiFunctionsBlockGUI\fillDataSection(), ilObjWikiGUI\getGotoLink(), ilWikiPage\getOrphanedPages(), and ilWikiPage\rename().

{
return ilObjWiki::_lookup($a_wiki_id, "startpage");
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

static ilObjWiki::_performSearch (   $a_wiki_id,
  $a_searchterm 
)
static

Search in Wiki.

Definition at line 530 of file class.ilObjWiki.php.

References ilObjectSearchFactory\_getWikiContentSearchInstance().

Referenced by ilObjWikiGUI\performSearchObject().

{
// query parser
include_once 'Services/Search/classes/class.ilQueryParser.php';
$query_parser = new ilQueryParser($a_searchterm);
$query_parser->setCombination("or");
$query_parser->parse();
include_once 'Services/Search/classes/class.ilSearchResult.php';
$search_result = new ilSearchResult();
if($query_parser->validate())
{
include_once 'Services/Search/classes/class.ilObjectSearchFactory.php';
$wiki_search->setFilter(array('wpg'));
$search_result->mergeEntries($wiki_search->performSearch());
}
$entries = $search_result->getEntries();
$found_pages = array();
foreach($entries as $entry)
{
if ($entry["obj_id"] == $a_wiki_id && is_array($entry["child"]))
{
foreach($entry["child"] as $child)
{
$found_pages[] = $child;
}
}
}
return $found_pages;
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjWiki::addImportantPage (   $a_page_id)

Add important page.

Parameters
intpage id

Definition at line 630 of file class.ilObjWiki.php.

References $ilDB, _lookupMaxOrdNrImportantPages(), ilObject\getId(), and isImportantPage().

{
global $ilDB;
if (!$this->isImportantPage($a_page_id))
{
$ilDB->manipulate("INSERT INTO il_wiki_imp_pages ".
"(wiki_id, ord, indent, page_id) VALUES (".
$ilDB->quote($this->getId(), "integer").",".
$ilDB->quote($nr, "integer").",".
$ilDB->quote(0, "integer").",".
$ilDB->quote($a_page_id, "integer").
")");
}
}

+ Here is the call graph for this function:

static ilObjWiki::checkShortTitleAvailability (   $a_short_title)
static

Check availability of short title.

Definition at line 352 of file class.ilObjWiki.php.

References $ilDB, and $res.

Referenced by ilObjWikiGUI\saveObject(), and ilObjWikiGUI\saveSettingsObject().

{
global $ilDB;
$res = $ilDB->queryF("SELECT id FROM il_wiki_data WHERE short = %s",
array("text"), array($a_short_title));
if ($ilDB->fetchAssoc($res))
{
return false;
}
return true;
}

+ Here is the caller graph for this function:

ilObjWiki::create (   $a_prevent_start_page_creation = false)

Create new wiki.

Definition at line 211 of file class.ilObjWiki.php.

References $ilDB, ilObject\create(), ilObject\getId(), getIntroduction(), getOnline(), getPublicNotes(), getRating(), getShortTitle(), getStartPage(), getStyleSheetId(), and ilObjStyleSheet\writeStyleUsage().

{
global $ilDB;
$ilDB->insert("il_wiki_data", array(
"id" => array("integer", $this->getId()),
"is_online" => array("integer", (int) $this->getOnline()),
"startpage" => array("text", $this->getStartPage()),
"short" => array("text", $this->getShortTitle()),
"rating" => array("integer", (int) $this->getRating()),
"public_notes" => array("integer", (int) $this->getPublicNotes()),
"introduction" => array("clob", $this->getIntroduction())
));
// create start page
if ($this->getStartPage() != "" && !$a_prevent_start_page_creation)
{
include_once("./Modules/Wiki/classes/class.ilWikiPage.php");
$start_page = new ilWikiPage();
$start_page->setWikiId($this->getId());
$start_page->setTitle($this->getStartPage());
$start_page->create();
}
if (((int) $this->getStyleSheetId()) > 0)
{
include_once("./Services/Style/classes/class.ilObjStyleSheet.php");
}
}

+ Here is the call graph for this function:

ilObjWiki::delete ( )

delete object and all related data

public

Returns
boolean true if all object data were removed; false if only a references were removed

Reimplemented from ilObject.

Definition at line 324 of file class.ilObjWiki.php.

References $ilDB, $query, ilWikiPage\deleteAllPagesOfWiki(), ilObject\getId(), ilNotification\removeForObject(), and ilNotification\TYPE_WIKI.

{
global $ilDB;
// always call parent delete function first!!
if (!parent::delete())
{
return false;
}
// delete record of table il_wiki_data
$query = "DELETE FROM il_wiki_data".
" WHERE id = ".$ilDB->quote($this->getId(), "integer");
$ilDB->manipulate($query);
// remove all notifications
include_once "./Services/Notification/classes/class.ilNotification.php";
include_once("./Modules/Wiki/classes/class.ilWikiPage.php");
return true;
}

+ Here is the call graph for this function:

ilObjWiki::fixImportantPagesNumbering ( )

Fix important pages numbering.

Definition at line 743 of file class.ilObjWiki.php.

References $ilDB, _lookupImportantPagesList(), and ilObject\getId().

Referenced by removeImportantPage().

{
global $ilDB;
// fix indentation: no 2 is allowed after a 0
$c_indent = 0;
$fixed = false;
foreach ($ipages as $k => $v)
{
if ($ipages[$k]["indent"] == 2 && $c_indent == 0)
{
$ipages[$k]["indent"] = 1;
$fixed = true;
}
$c_indent = $ipages[$k]["indent"];
}
$ord = 10;
foreach ($ipages as $k => $v)
{
$ilDB->manipulate($q = "UPDATE il_wiki_imp_pages SET ".
" ord = ".$ilDB->quote($ord, "integer").
", indent = ".$ilDB->quote($v["indent"], "integer").
" WHERE wiki_id = ".$ilDB->quote($v["wiki_id"], "integer").
" AND page_id = ".$ilDB->quote($v["page_id"], "integer")
);
$ord+=10;
}
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjWiki::getImportantPages ( )

Get important pages.

Returns
boolean important pages

Definition at line 107 of file class.ilObjWiki.php.

Referenced by update().

{
return $this->imp_pages;
}

+ Here is the caller graph for this function:

ilObjWiki::getIntroduction ( )

Get Introduction.

Returns
string Introduction

Definition at line 167 of file class.ilObjWiki.php.

Referenced by create(), and update().

{
return $this->introduction;
}

+ Here is the caller graph for this function:

ilObjWiki::getOnline ( )

Get Online.

Returns
boolean Online

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

References $online.

Referenced by create(), and update().

{
return $this->online;
}

+ Here is the caller graph for this function:

ilObjWiki::getPageToc ( )

Get page toc.

Returns
boolean page toc

Definition at line 203 of file class.ilObjWiki.php.

Referenced by update().

{
return $this->page_toc;
}

+ Here is the caller graph for this function:

ilObjWiki::getPublicNotes ( )

Get public notes.

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

References $public_notes.

Referenced by create(), and update().

{
}

+ Here is the caller graph for this function:

ilObjWiki::getRating ( )

Get Enable Rating.

Returns
boolean Enable Rating

Definition at line 71 of file class.ilObjWiki.php.

Referenced by create(), and update().

{
return $this->rating;
}

+ Here is the caller graph for this function:

ilObjWiki::getShortTitle ( )

Get ShortTitle.

Returns
string ShortTitle

Definition at line 147 of file class.ilObjWiki.php.

Referenced by create(), and update().

{
return $this->shorttitle;
}

+ Here is the caller graph for this function:

ilObjWiki::getStartPage ( )

Get Start Page.

Returns
string Start Page

Definition at line 127 of file class.ilObjWiki.php.

Referenced by create(), and update().

{
return $this->startpage;
}

+ Here is the caller graph for this function:

ilObjWiki::getStyleSheetId ( )

get ID of assigned style sheet object

Definition at line 175 of file class.ilObjWiki.php.

Referenced by create(), and update().

{
return $this->style_id;
}

+ Here is the caller graph for this function:

ilObjWiki::ilObjWiki (   $a_id = 0,
  $a_call_by_reference = true 
)

Constructor public.

Parameters
integerreference_id or object_id
booleantreat the id as reference_id (true) or object_id (false)

Definition at line 30 of file class.ilObjWiki.php.

References ilObject\ilObject().

{
$this->type = "wiki";
$this->ilObject($a_id,$a_call_by_reference);
}

+ Here is the call graph for this function:

ilObjWiki::initDefaultRoles ( )

init default roles settings

If your module does not require any default roles, delete this method (For an example how this method is used, look at ilObjForum)

public

Returns
array object IDs of created local roles.

Reimplemented from ilObject.

Definition at line 375 of file class.ilObjWiki.php.

{
global $rbacadmin;
// create a local role folder
//$rfoldObj = $this->createRoleFolder("Local roles","Role Folder of forum obj_no.".$this->getId());
// create moderator role and assign role to rolefolder...
//$roleObj = $rfoldObj->createRole("Moderator","Moderator of forum obj_no.".$this->getId());
//$roles[] = $roleObj->getId();
//unset($rfoldObj);
//unset($roleObj);
return $roles ? $roles : array();
}
ilObjWiki::isImportantPage (   $a_page_id)

Is page an important page?

Parameters
@return

Definition at line 654 of file class.ilObjWiki.php.

References $ilDB.

Referenced by addImportantPage().

{
global $ilDB;
$set = $ilDB->query("SELECT * FROM il_wiki_imp_pages WHERE ".
" wiki_id = ".$ilDB->quote($this->getId(), "integer")." AND ".
" page_id = ".$ilDB->quote($a_page_id, "integer")
);
if ($rec = $ilDB->fetchAssoc($set))
{
return true;
}
return false;
}

+ Here is the caller graph for this function:

ilObjWiki::notify (   $a_event,
  $a_ref_id,
  $a_parent_non_rbac_id,
  $a_node_id,
  $a_params = 0 
)

notifys an object about an event occured Based on the event happend, each object may decide how it reacts.

If you are not required to handle any events related to your module, just delete this method. (For an example how this method is used, look at ilObjGroup)

public

Parameters
stringevent
integerreference id of object where the event occured
arraypasses optional parameters if required
Returns
boolean

Reimplemented from ilObject.

Definition at line 405 of file class.ilObjWiki.php.

References $_GET, and ilObject\getType().

{
global $tree;
switch ($a_event)
{
case "link":
//var_dump("<pre>",$a_params,"</pre>");
//echo "Module name ".$this->getRefId()." triggered by link event. Objects linked into target object ref_id: ".$a_ref_id;
//exit;
break;
case "cut":
//echo "Module name ".$this->getRefId()." triggered by cut event. Objects are removed from target object ref_id: ".$a_ref_id;
//exit;
break;
case "copy":
//var_dump("<pre>",$a_params,"</pre>");
//echo "Module name ".$this->getRefId()." triggered by copy event. Objects are copied into target object ref_id: ".$a_ref_id;
//exit;
break;
case "paste":
//echo "Module name ".$this->getRefId()." triggered by paste (cut) event. Objects are pasted into target object ref_id: ".$a_ref_id;
//exit;
break;
case "new":
//echo "Module name ".$this->getRefId()." triggered by paste (new) event. Objects are applied to target object ref_id: ".$a_ref_id;
//exit;
break;
}
// At the beginning of the recursive process it avoids second call of the notify function with the same parameter
if ($a_node_id==$_GET["ref_id"])
{
$parent_obj =& $this->ilias->obj_factory->getInstanceByRefId($a_node_id);
$parent_type = $parent_obj->getType();
if($parent_type == $this->getType())
{
$a_node_id = (int) $tree->getParentId($a_node_id);
}
}
parent::notify($a_event,$a_ref_id,$a_parent_non_rbac_id,$a_node_id,$a_params);
}

+ Here is the call graph for this function:

ilObjWiki::read ( )

Read wiki data.

Definition at line 292 of file class.ilObjWiki.php.

References $ilDB, $query, ilObject\getId(), ilObjStyleSheet\lookupObjectStyle(), setImportantPages(), setIntroduction(), setOnline(), setPageToc(), setPublicNotes(), setRating(), setShortTitle(), setStartPage(), and setStyleSheetId().

{
global $ilDB;
$query = "SELECT * FROM il_wiki_data WHERE id = ".
$ilDB->quote($this->getId(), "integer");
$set = $ilDB->query($query);
$rec = $ilDB->fetchAssoc($set);
$this->setOnline($rec["is_online"]);
$this->setStartPage($rec["startpage"]);
$this->setShortTitle($rec["short"]);
$this->setRating($rec["rating"]);
$this->setPublicNotes($rec["public_notes"]);
$this->setIntroduction($rec["introduction"]);
$this->setImportantPages($rec["imp_pages"]);
$this->setPageToc($rec["page_toc"]);
include_once("./Services/Style/classes/class.ilObjStyleSheet.php");
}

+ Here is the call graph for this function:

ilObjWiki::removeImportantPage (   $a_id)

Remove important page.

Parameters
intpage id

Definition at line 674 of file class.ilObjWiki.php.

References $ilDB, and fixImportantPagesNumbering().

{
global $ilDB;
$ilDB->manipulate("DELETE FROM il_wiki_imp_pages WHERE "
." wiki_id = ".$ilDB->quote($this->getId(), "integer")
." AND page_id = ".$ilDB->quote($a_id, "integer")
);
}

+ Here is the call graph for this function:

ilObjWiki::saveOrderingAndIndentation (   $a_ord,
  $a_indent 
)

Save ordering and indentation.

Parameters
@return

Definition at line 692 of file class.ilObjWiki.php.

References $ilDB, _lookupImportantPagesList(), ilObject\getId(), and ilUtil\sortArray().

{
global $ilDB;
foreach ($ipages as $k => $v)
{
if (isset($a_ord[$v["page_id"]]))
{
$ipages[$k]["ord"] = (int) $a_ord[$v["page_id"]];
}
if (isset($a_indent[$v["page_id"]]))
{
$ipages[$k]["indent"] = (int) $a_indent[$v["page_id"]];
}
}
$ipages = ilUtil::sortArray($ipages, "ord", "asc", true);
// fix indentation: no 2 is allowed after a 0
$c_indent = 0;
$fixed = false;
foreach ($ipages as $k => $v)
{
if ($ipages[$k]["indent"] == 2 && $c_indent == 0)
{
$ipages[$k]["indent"] = 1;
$fixed = true;
}
$c_indent = $ipages[$k]["indent"];
}
$ord = 10;
reset($ipages);
foreach ($ipages as $k => $v)
{
$ilDB->manipulate($q = "UPDATE il_wiki_imp_pages SET ".
" ord = ".$ilDB->quote($ord, "integer").",".
" indent = ".$ilDB->quote($v["indent"], "integer").
" WHERE wiki_id = ".$ilDB->quote($v["wiki_id"], "integer").
" AND page_id = ".$ilDB->quote($v["page_id"], "integer")
);
$ord+=10;
}
return $fixed;
}

+ Here is the call graph for this function:

ilObjWiki::setImportantPages (   $a_val)

Set important pages.

Parameters
boolean$a_valimportant pages

Definition at line 97 of file class.ilObjWiki.php.

Referenced by read().

{
$this->imp_pages = $a_val;
}

+ Here is the caller graph for this function:

ilObjWiki::setIntroduction (   $a_introduction)

Set Introduction.

Parameters
string$a_introductionIntroduction

Definition at line 157 of file class.ilObjWiki.php.

Referenced by read().

{
$this->introduction = $a_introduction;
}

+ Here is the caller graph for this function:

ilObjWiki::setOnline (   $a_online)

Set Online.

Parameters
boolean$a_onlineOnline

Definition at line 41 of file class.ilObjWiki.php.

Referenced by read().

{
$this->online = $a_online;
}

+ Here is the caller graph for this function:

ilObjWiki::setPageToc (   $a_val)

Set page toc.

Parameters
boolean$a_valpage toc

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

Referenced by read().

{
$this->page_toc = $a_val;
}

+ Here is the caller graph for this function:

ilObjWiki::setPublicNotes (   $a_val)

Set public notes.

Definition at line 79 of file class.ilObjWiki.php.

Referenced by read().

{
$this->public_notes = $a_val;
}

+ Here is the caller graph for this function:

ilObjWiki::setRating (   $a_rating)

Set Enable Rating.

Parameters
boolean$a_ratingEnable Rating

Definition at line 61 of file class.ilObjWiki.php.

Referenced by read().

{
$this->rating = $a_rating;
}

+ Here is the caller graph for this function:

ilObjWiki::setShortTitle (   $a_shorttitle)

Set ShortTitle.

Parameters
string$a_shorttitleShortTitle

Definition at line 137 of file class.ilObjWiki.php.

Referenced by read().

{
$this->shorttitle = $a_shorttitle;
}

+ Here is the caller graph for this function:

ilObjWiki::setStartPage (   $a_startpage)

Set Start Page.

Parameters
string$a_startpageStart Page

Definition at line 117 of file class.ilObjWiki.php.

References ilWikiUtil\makeDbTitle().

Referenced by read().

{
$this->startpage = ilWikiUtil::makeDbTitle($a_startpage);
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjWiki::setStyleSheetId (   $a_style_id)

set ID of assigned style sheet object

Definition at line 183 of file class.ilObjWiki.php.

Referenced by read().

{
$this->style_id = $a_style_id;
}

+ Here is the caller graph for this function:

ilObjWiki::update (   $a_prevent_start_page_creation = false)

update object data

public

Returns
boolean

Definition at line 250 of file class.ilObjWiki.php.

References $ilDB, ilWikiPage\exists(), ilObject\getId(), getImportantPages(), getIntroduction(), getOnline(), getPageToc(), getPublicNotes(), getRating(), getShortTitle(), getStartPage(), getStyleSheetId(), and ilObjStyleSheet\writeStyleUsage().

{
global $ilDB;
if (!parent::update())
{
return false;
}
$ilDB->update("il_wiki_data", array(
"is_online" => array("integer", $this->getOnline()),
"startpage" => array("text", $this->getStartPage()),
"short" => array("text", $this->getShortTitle()),
"rating" => array("integer", $this->getRating()),
"public_notes" => array("integer", $this->getPublicNotes()),
"introduction" => array("clob", $this->getIntroduction()),
"imp_pages" => array("integer", $this->getImportantPages()),
"page_toc" => array("integer", $this->getPageToc())
), array(
"id" => array("integer", $this->getId())
));
// check whether start page exists
include_once("./Modules/Wiki/classes/class.ilWikiPage.php");
if (!ilWikiPage::exists($this->getId(), $this->getStartPage())
&& !$a_prevent_start_page_creation)
{
$start_page = new ilWikiPage();
$start_page->setWikiId($this->getId());
$start_page->setTitle($this->getStartPage());
$start_page->create();
}
include_once("./Services/Style/classes/class.ilObjStyleSheet.php");
return true;
}

+ Here is the call graph for this function:

static ilObjWiki::writeStartPage (   $a_id,
  $a_name 
)
static

Write start page.

Definition at line 516 of file class.ilObjWiki.php.

References $ilDB, and ilWikiUtil\makeDbTitle().

Referenced by ilWikiPage\rename().

{
global $ilDB;
include_once("./Modules/Wiki/classes/class.ilWikiUtil.php");
$ilDB->manipulate("UPDATE il_wiki_data SET ".
" startpage = ".$ilDB->quote(ilWikiUtil::makeDbTitle($a_name), "text").
" WHERE id = ".$ilDB->quote($a_id, "integer")
);
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

Field Documentation

ilObjWiki::$online = false
protected

Definition at line 21 of file class.ilObjWiki.php.

Referenced by getOnline().

ilObjWiki::$public_notes = true
protected

Definition at line 22 of file class.ilObjWiki.php.

Referenced by getPublicNotes().


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