X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Fupdate-gosa;h=55214d133d92abce2ba557858b96896ab11558e8;hb=049641fae8b746c2903149dc64219f4a758124a5;hp=22a4cb1fb59af72d5126cd7cce2d25ea2b01acc9;hpb=a6f49189f115f147f15a87cc05f3c75e94c5b3dc;p=gosa.git diff --git a/gosa-core/update-gosa b/gosa-core/update-gosa index 22a4cb1fb..55214d133 100755 --- a/gosa-core/update-gosa +++ b/gosa-core/update-gosa @@ -1,31 +1,66 @@ -#!/usr/bin/php5 +#!/usr/bin/php update-gosa - class cache updated and plugin manager for GOsa -Usage: update-gosa install-plugin dir Install the plugin placed in "dir" to - the GOsa tree. +Usage: update-gosa install dsc Install the plugin using the dsc information + placed in the plugin source directory. - update-gosa remove-plugin plugin Remove the plugin named "plugin" from - the current configuration. + update-gosa remove plugin Remove the plugin named "plugin" from + the current configuration. - update-gosa list-plugins Lists installed plugins + update-gosa list Lists installed plugins - update-gosa rescan-i18n Rebuilds the translations + update-gosa rescan-i18n Rebuilds the translations - update-gosa rescan-classes Rebuilds the class list + update-gosa rescan-classes Rebuilds the class list - update-gosa Shortcut for rescan-classes and rescan-i18n + update-gosa Shortcut for rescan-classes and rescan-i18n $value){ fwrite ($handle, " \"$key\" => \"$value\",\n"); } - fwrite ($handle, " );\n?>"); + fwrite ($handle, " );\n"); fclose($handle); } @@ -138,7 +177,7 @@ function rescan_i18n() } /* Cat all these po files into one single file */ - system ("(cd ".LOCALE_DIR." && msgcat ".implode(" ", $po_files)." > compiled/${language}/LC_MESSAGES/messages.po)", $val); + system ("(cd ".LOCALE_DIR." && msgcat --use-first ".implode(" ", $po_files)." > compiled/${language}/LC_MESSAGES/messages.po)", $val); if ($val != 0){ echo "Merging of message files failed - aborted"; exit (4); @@ -149,12 +188,66 @@ function rescan_i18n() exit (5); } } + + echo "! Warning: you may need to reload your webservice!\n"; +} + + +function rescan_guide() +{ + $master_guide= "doc/guide.xml"; + echo "Updating Online Help Index...\n"; + $master_guide_content="\n". + "\n\n". + "\n\n". + "\n". + "\n"; + + $guide= 'doc/core/guide.xml'; + if(file_exists($guide) && is_readable($guide)) { + $master_guide_content.= file_get_contents($guide); + } + + if(file_exists('doc/plugins')) { + $plugins= scandir('doc/plugins'); + foreach($plugins as $key => $plugin) { + if($plugin != '.' && $plugin != '..') { + if(is_dir('doc/plugins/'.$plugin)) { + $guide= 'doc/plugins/'.$plugin.'/guide.xml'; + if(file_exists($guide) && is_readable($guide)) { + $master_guide_content.= file_get_contents($guide); + } + } + } + } + } + + $master_guide_content.= ""; + + $master_guide_content= preg_replace("/[ \t][ \t]*/", " ", $master_guide_content); + + if((file_exists($master_guide) && is_writable($master_guide)) || is_writable('doc')) { + file_put_contents($master_guide, $master_guide_content); + } + } function parse_ini($file) { - global $description, $provides, $depends; + global $description, $provides, $depends, $versions, $conflicts; $res= ""; if (file_exists($file)){ @@ -162,13 +255,17 @@ function parse_ini($file) if (isset($tmp['gosa-plugin'])){ $plugin= &$tmp['gosa-plugin']; - if (isset($plugin['name'])&& isset($plugin['description']) && isset($plugin['provides'])){ + if (isset($plugin['name'])&& isset($plugin['description'])){ $res= $plugin['name']; - $provides[$res]= $plugin['provides']; $description[$res]= $plugin['description']; + $versions[$res]= $plugin['version']; + $provides[$res]= $res; if (isset($plugin['depends'])){ $depends[$res]= explode(',', preg_replace('/\s+/', '', $plugin['depends'])); } + if (isset($plugin['conflicts'])){ + $conflicts[$res]= explode(',', preg_replace('/\s+/', '', $plugin['conflicts'])); + } } } } @@ -194,7 +291,7 @@ function dependency_check() function load_plugins() { - if (!file_exists(PLUGSTATE_DIR)){ + if (!is_dir(PLUGSTATE_DIR)){ if (!mkdir (PLUGSTATE_DIR, 0755, TRUE)){ echo "Cannot create plugstate dir '".PLUGSTATE_DIR."' - aborted\n"; exit (2); @@ -204,7 +301,7 @@ function load_plugins() foreach ($dir as $entry){ if ($dir->isDir() && !preg_match('/^\./', $dir->__toString())){ $file= $dir->getPathName()."/plugin.dsc"; - if (!parse_ini($file)){ + if (parse_ini($file) == ""){ echo "! Warning: plugin ".$dir->getPathName()." is missing declarations\n"; } } @@ -214,7 +311,7 @@ function load_plugins() function list_plugins() { - global $description; + global $description, $versions; $count= 0; /* Load plugin list */ @@ -223,10 +320,11 @@ function list_plugins() /* Show plugins */ foreach ($description as $name => $dsc){ if ($count == 0){ - echo "Plugin\t\t| Description\n"; - echo "------------------------------------------------------------------------\n"; + echo "Plugin\t\t|Version |Description\n"; + echo "----------------------------------------------------------------------------\n"; } - echo "* $name\t\t| ".$dsc."\n"; + $ver= $versions[$name]; + echo "$name\t\t|$ver\t |$dsc\n"; $count++; } @@ -241,49 +339,219 @@ function list_plugins() } -function install_plugin($name) +function install_plugin($file) { - global $description, $provides, $depends; + global $description, $provides, $depends, $conflicts; + + /* Load plugin list */ + load_plugins(); + + /* Load .dsc file */ + if (file_exists($file)){ + $tmp= parse_ini_file($file, TRUE); + + if (isset($tmp['gosa-plugin'])){ + $plugin= &$tmp['gosa-plugin']; + if (isset($plugin['name'])&& isset($plugin['description'])){ + $name= $plugin['name']; + $description= $plugin['description']; + $depends= array(); + if (isset($plugin['depends'])){ + $depends= explode(',', preg_replace('/\s+/', '', $plugin['depends'])); + } + + /* Already installed? */ + if (isset($provides[$name])){ + echo "! Error: plugin already installed\n\n"; + exit (3); + } + + /* Check if dependencies are fullfilled */ + foreach ($depends as $dep){ + $found= false; + foreach ($provides as $provide => $dummy){ + if ($dep == $provide){ + $found= true; + break; + } + } + if (!$found){ + echo "! Error: plugin depends on '$dep', but this is not installed\n\n"; + exit (3); + } + } + + /* Check for conflicts */ + foreach ($conflicts as $conf){ + if (!in_array($conf, $provides)){ + echo "! Warning: plugin conflicts with '$conf'\n\n"; + } + } + + /* Create plugstate directory and touch plugin.lst */ + if (!mkdir (PLUGSTATE_DIR."/$name", 0755, TRUE)){ + echo "Failed to create '".PLUGSTATE_DIR."/$name - aborted"; + exit (3); + } + if (!$handle= fopen(PLUGSTATE_DIR."/$name/plugin.lst", 'w')) { + echo "Cannot open file '$filename' - aborted\n"; + exit (1); + } + + echo "Installing plugin '$name'...\n"; + + /* Copy and fill plugin.lst */ + $path= dirname($file); + $dir= new RecursiveDirectoryIterator($path); + $all= new RecursiveIteratorIterator($dir); + foreach ( $all as $entry ){ + $source= $path."/".substr($entry->getPathName(), strlen($path) + 1); + + /* Skip description - it belongs to the state dir */ + if (preg_match('/\/plugin.dsc$/', $source)){ + copy ($source, PLUGSTATE_DIR."/$name/plugin.dsc"); + continue; + } + + /* Skip well known directories */ + if (preg_match('/^\.+$/', $source) || preg_match('/\/\.svn\//', $source)) { + continue; + } + + /* Calculate destination */ + if (preg_match("%^.*locale/%", $source)){ + $dest= GOSA_HOME."/locale/plugins/$name/".preg_replace("%^.*locale/%", "", $source); + } elseif (preg_match("%^.*help/%", $source)) { + $dest= GOSA_HOME."/doc/plugins/$name/".preg_replace("%^.*help/%", "", $source); + } elseif (preg_match("%^.*html/%", $source)) { + $dest= GOSA_HOME."/html/plugins/$name/".preg_replace("%^.*html/%", "", $source); + } else { + $dest= GOSA_HOME."/plugins/".substr($entry->getPathName(), strlen($path) + 1); + } + + /* Destination exists in case of directories? */ + if ($entry->isDir()){ + if (!is_dir($dest)){ + mkdir($dest, 0755, TRUE); + fwrite ($handle, "$dest\n"); + } + } else { + if (!is_dir(dirname($dest))){ + mkdir(dirname($dest), 0755, TRUE); + fwrite ($handle, dirname($dest)."\n"); + } + } + + /* Copy files */ + if ($entry->isFile()){ + copy ($source, $dest); + } + + /* Note what we did... */ + fwrite ($handle, "$dest\n"); + } + + fclose($handle); + } + } + } + + /* Update caches */ + rescan_classes(); + rescan_i18n(); + rescan_guide(); +} + + +function remove_plugin($name) +{ + global $description, $depends; /* Load plugin list */ load_plugins(); - # go to the directory, load dsc file - # check if it already there - # check if all dependencies are fullfilled - # copy plugin - # update classlist - # update i18n + /* Present? */ + if (!isset($description[$name])){ + echo "! Error: cannot find a plugin named '$name'\n\n"; + exit (1); + } + + /* Depends? */ + foreach ($depends as $sname => $pl_depends){ + if (in_array($name, $pl_depends)){ + echo "! Error: plugin '$sname' depends on '$name' - cannot remove it\n\n"; + exit (1); + } + } + + /* Load information */ + if (!file_exists(PLUGSTATE_DIR."/$name/plugin.lst")){ + echo "! Error: cannot remove plugin '$name' - no install history found\n\n"; + exit (1); + } - #if (isset($)){ - #} + echo "Removing plugin '$name'...\n"; + $contents= file(PLUGSTATE_DIR."/$name/plugin.lst"); + $cnv= array(); + foreach($contents as $line){ + $entry= chop($line); + $cnv[strlen($entry).":$entry"]= $entry; + } + krsort($cnv); + + /* Remove files first */ + clearstatcache(); + foreach ($cnv as $entry){ + if (is_dir($entry)){ + rmdir($entry); + continue; + } + if (file_exists($entry)){ + unlink($entry); + } + } + + /* Remove state directory for plugin */ + rmdirRecursive(PLUGSTATE_DIR."/$name"); + + /* Update caches */ + rescan_classes(); + rescan_i18n(); + rescan_guide(); } + /* Fill global values */ -$description= $provides= $depends= array(); +$description= $provides= $depends= $versions= $conflicts= array(); /* Action specified? */ if ($argc < 2){ rescan_classes(); rescan_i18n(); + rescan_guide(); exit (0); } switch ($argv[1]){ - case 'install-plugin': + case 'install': if (isset($argv[2])){ install_plugin($argv[2]); } else { - echo "Usage: update-gosa install-plugin directory\n\n"; + echo "Usage: update-gosa install dsc-file\n\n"; exit (1); } break; - case 'list-plugins': + case 'list': list_plugins(); break; - case 'remove-plugin': - echo "remove\n"; + case 'remove': + if (isset($argv[2])){ + remove_plugin($argv[2]); + } else { + echo "Usage: update-gosa remove plugin-name\n\n"; + exit (1); + } break; case 'rescan-i18n': rescan_i18n();