diff options
author | sembrestels <sembrestels@riseup.net> | 2011-10-13 04:58:09 +0200 |
---|---|---|
committer | sembrestels <sembrestels@riseup.net> | 2011-10-13 04:58:09 +0200 |
commit | b022f5df563d9b0f09618d0f70cad09ac3f1143d (patch) | |
tree | 61ac1e5a216981f367f8f712992eb04622f738c8 | |
parent | c288d2c46f31c640bdc2609b751a012b1c69f3d6 (diff) | |
download | elgg-b022f5df563d9b0f09618d0f70cad09ac3f1143d.tar.gz elgg-b022f5df563d9b0f09618d0f70cad09ac3f1143d.tar.bz2 |
Moved not always used functions to a library.
-rw-r--r-- | lib/dokuwiki.php | 62 | ||||
-rw-r--r-- | start.php | 62 |
2 files changed, 67 insertions, 57 deletions
diff --git a/lib/dokuwiki.php b/lib/dokuwiki.php new file mode 100644 index 000000000..af2e14b8d --- /dev/null +++ b/lib/dokuwiki.php @@ -0,0 +1,62 @@ +<?php + +function current_dokuwiki_entity($create = true) { + $page_owner = page_owner(); + $user = get_loggedin_user(); + //error_log($page_owner->guid); + //error_log($user->guid); + if (!$page_owner) + $page_owner = 0; + $entities = elgg_get_entities(array('types' => 'object', 'subtypes' => 'dokuwiki', 'limit' => 1, 'owner_guid' => $page_owner)); + if ($entities) { + $doku = $entities[0]; + return $doku; + } + elseif ($user && $create) { + elgg_set_ignore_access(true); + $newdoku = new ElggObject(); + $newdoku->access_id = ACCESS_PUBLIC; + $newdoku->owner_guid = $page_owner; + $newdoku->subtype = 'dokuwiki'; + $newdoku->container_guid = $page_owner; + $newdoku->save(); + $acl = array(); + $acl[] = "# acl.auth.php"; + $acl[] = '# <?php exit()?\>'; + $acl[] = "* @ALL 0"; + $acl[] = "* @user 1"; + $acl[] = "* @member 8"; + $acl[] = "* @admin 16"; + $acl[] = "* @root 255"; + $newdoku->wiki_acl = implode("\n", $acl)."\n"; + elgg_set_ignore_access(false); + return $newdoku; + } +} + +function elggdoku_recurse_copy($src,$dst) { + $dir = opendir($src); + @mkdir($dst); + while(false !== ( $file = readdir($dir)) ) { + if (( $file != '.' ) && ( $file != '..' )) { + if ( is_dir($src . '/' . $file) ) { + elggdoku_recurse_copy($src . '/' . $file,$dst . '/' . $file); + } + else { + copy($src . '/' . $file,$dst . '/' . $file); + } + } + } + closedir($dir); +} + +function elggdokuwiki_create_datafolder($path) { + if (is_dir($path)) // if it exists must be already created + return; + mkdir($path, 0700, true); + $orig = elgg_get_plugins_path().'dokuwiki/lib/dokuwiki/data'; + elggdoku_recurse_copy($orig, $path); + +} + +?> @@ -9,64 +9,7 @@ * @link http://lorea.cc */ - function current_dokuwiki_entity($create = true) { - $page_owner = page_owner(); - $user = get_loggedin_user(); - //error_log($page_owner->guid); - //error_log($user->guid); - if (!$page_owner) - $page_owner = 0; - $entities = elgg_get_entities(array('types' => 'object', 'subtypes' => 'dokuwiki', 'limit' => 1, 'owner_guid' => $page_owner)); - if ($entities) { - $doku = $entities[0]; - return $doku; - } - elseif ($user && $create) { - elgg_set_ignore_access(true); - $newdoku = new ElggObject(); - $newdoku->access_id = ACCESS_PUBLIC; - $newdoku->owner_guid = $page_owner; - $newdoku->subtype = 'dokuwiki'; - $newdoku->container_guid = $page_owner; - $newdoku->save(); - $acl = array(); - $acl[] = "# acl.auth.php"; - $acl[] = '# <?php exit()?\>'; - $acl[] = "* @ALL 0"; - $acl[] = "* @user 1"; - $acl[] = "* @member 8"; - $acl[] = "* @admin 16"; - $acl[] = "* @root 255"; - $newdoku->wiki_acl = implode("\n", $acl)."\n"; - elgg_set_ignore_access(false); - return $newdoku; - } - } - function elggdoku_recurse_copy($src,$dst) { - $dir = opendir($src); - @mkdir($dst); - while(false !== ( $file = readdir($dir)) ) { - if (( $file != '.' ) && ( $file != '..' )) { - if ( is_dir($src . '/' . $file) ) { - elggdoku_recurse_copy($src . '/' . $file,$dst . '/' . $file); - } - else { - copy($src . '/' . $file,$dst . '/' . $file); - } - } - } - closedir($dir); - } - - function elggdokuwiki_create_datafolder($path) { - if (is_dir($path)) // if it exists must be already created - return; - mkdir($path, 0700, true); - $orig = elgg_get_plugins_path().'dokuwiki/lib/dokuwiki/data'; - elggdoku_recurse_copy($orig, $path); - - } /** * Dispatches dokuwiki pages. @@ -78,6 +21,9 @@ * @return NULL */ function dokuwiki_page_handler($page) { + + elgg_load_library('elgg:dokuwiki'); + if ($page[0] === "all") { set_context("search"); include(elgg_get_plugins_path().'dokuwiki/index.php'); @@ -186,6 +132,8 @@ function elggdokuwiki_init(){ + elgg_register_library('elgg:dokuwiki', elgg_get_plugins_path().'dokuwiki/lib/dokuwiki.php'); + register_entity_type('object','dokuwiki'); register_plugin_hook('entity:icon:url', 'object', 'elggdokuwiki_icon_hook'); register_entity_url_handler('elggdokuwiki_url','object', 'dokuwiki'); |