summaryrefslogtreecommitdiffstats
path: root/os-plugins
diff options
context:
space:
mode:
authorBastian Wissler2008-07-10 16:54:12 +0200
committerBastian Wissler2008-07-10 16:54:12 +0200
commit695210830b60f955536bfff7f720d9bee07a870e (patch)
tree0b81e7ffd47b2b4272c3afa2fdd972ad9f53e030 /os-plugins
parent<priority param="integer" /> recognized in display - pics smaller [ vmchooser ] (diff)
downloadcore-695210830b60f955536bfff7f720d9bee07a870e.tar.gz
core-695210830b60f955536bfff7f720d9bee07a870e.tar.xz
core-695210830b60f955536bfff7f720d9bee07a870e.zip
some changes to vmchooser + initial import for bindrivers plugins
git-svn-id: http://svn.openslx.org/svn/openslx/openslx/trunk@1908 95ad53e4-c205-0410-b2fa-d234c58c8868
Diffstat (limited to 'os-plugins')
-rw-r--r--os-plugins/plugins/bindrivers/OpenSLX/OSPlugin/bindrivers.pm155
-rw-r--r--os-plugins/plugins/bindrivers/XX_bindrivers.sh38
-rw-r--r--os-plugins/plugins/vmchooser/OpenSLX/OSPlugin/vmchooser.pm3
-rw-r--r--os-plugins/plugins/vmchooser/XX_vmchooser.sh2
-rwxr-xr-xos-plugins/plugins/vmchooser/files/xmlfilter.sh24
5 files changed, 220 insertions, 2 deletions
diff --git a/os-plugins/plugins/bindrivers/OpenSLX/OSPlugin/bindrivers.pm b/os-plugins/plugins/bindrivers/OpenSLX/OSPlugin/bindrivers.pm
new file mode 100644
index 00000000..1dbdd522
--- /dev/null
+++ b/os-plugins/plugins/bindrivers/OpenSLX/OSPlugin/bindrivers.pm
@@ -0,0 +1,155 @@
+# Copyright (c) 2008 - OpenSLX GmbH
+#
+# This program is free software distributed under the GPL version 2.
+# See http://openslx.org/COPYING
+#
+# If you have any feedback please consult http://openslx.org/feedback and
+# send your suggestions, praise, or complaints to feedback@openslx.org
+#
+# General information about OpenSLX can be found at http://openslx.org/
+# -----------------------------------------------------------------------------
+# example.pm
+# - an example implementation of the OSPlugin API (i.e. an os-plugin)
+# -----------------------------------------------------------------------------
+package OpenSLX::OSPlugin::bindrivers;
+
+use strict;
+use warnings;
+
+use base qw(OpenSLX::OSPlugin::Base);
+
+use OpenSLX::Basics;
+use OpenSLX::Utils;
+
+################################################################################
+# if you have any questions regarding the concept of OS-plugins and their
+# implementation, please drop a mail to: ot@openslx.com, or join the IRC-channel
+# '#openslx' (on freenode).
+################################################################################
+sub new
+{
+ my $class = shift;
+
+ my $self = {
+ name => 'example',
+ };
+
+ return bless $self, $class;
+}
+
+sub getInfo
+{
+ my $self = shift;
+
+ return {
+ description => unshiftHereDoc(<<' End-of-Here'),
+ This plugin tries to integrate binary graphics drivers into the system.
+ Notice that you need to have kernel-headers installed to work properly.
+ End-of-Here
+ precedence => 50,
+ };
+}
+
+sub getAttrInfo
+{ # returns a hash-ref with information about all attributes supported
+ # by this specific plugin
+ my $self = shift;
+
+ # This default configuration will be added as attributes to the default
+ # system, such that it can be overruled for any specific system by means
+ # of slxconfig.
+ return {
+ # attribute 'active' is mandatory for all plugins
+ 'bindrivers::active' => {
+ applies_to_systems => 1,
+ applies_to_clients => 0,
+ description => unshiftHereDoc(<<' End-of-Here'),
+ should the 'example'-plugin be executed during boot?
+ End-of-Here
+ content_regex => qr{^(0|1)$},
+ content_descr => '1 means active - 0 means inactive',
+ default => '1',
+ },
+
+ # plugin specific attributes start here ...
+ 'bindrivers::preferred_side' => {
+ applies_to_systems => 1,
+ applies_to_clients => 0,
+ description => unshiftHereDoc(<<' End-of-Here'),
+ determines to which side you have to tilt your head in order
+ to read the smiley
+ End-of-Here
+ content_regex => qr{^(left|right)$},
+ content_descr => q{'left' will print ';-)' - 'right' will print '(-;'},
+ default => 'left',
+ },
+ };
+}
+
+sub installationPhase
+{ # called while chrooted to the vendor-OS root in order to give the plugin
+ # a chance to install required files into the vendor-OS.
+ my $self = shift;
+ my $info = shift;
+
+ my $pluginRepoPath = $info->{'plugin-repo-path'};
+ # The folder where the stage1-plugin should store all files
+ # required by the corresponding stage3 runlevel script.
+ # As this method is being executed while chrooted into the vendor-OS,
+ # this path is relative to that root (i.e. directly usable).
+ my $pluginTempPath = $info->{'plugin-temp-path'};
+ # A temporary playground that will be cleaned up automatically.
+ # As this method is being executed while chrooted into the vendor-OS,
+ # this path is relative to that root (i.e. directly usable).
+ my $openslxBasePath = $info->{'openslx-base-path'};
+ # the openslx base path (/opt/openslx) bind-mounted into the chroot
+ my $openslxConfigPath = $info->{'openslx-config-path'};
+ # the openslx config path (/etc/opt/openlsx) bind-mounted into the
+ # chroot
+ my $attrs = $info->{'plugin-attrs'};
+ # attributes in effect for this installation
+
+ # for this example plugin, we simply create two files:
+ spitFile("$pluginRepoPath/right", "(-;\n");
+ spitFile("$pluginRepoPath/left", ";-)\n");
+
+ # Some plugins have to copy files from their plugin folder into the
+ # vendor-OS. Here's an example for how to do that:
+ #
+ # # get our own name:
+ # my $pluginName = $self->{'name'};
+ #
+ # # get our own base path:
+ # my $pluginBasePath = "$openslxBasePath/lib/plugins/$pluginName";
+ #
+ # # copy all needed files now:
+ # foreach my $file ( qw( file1, file2 ) ) {
+ # copyFile("$pluginBasePath/$file", "$pluginRepoPath/");
+ # }
+
+ # name of current os
+ # my $vendorOSName = $self->{'os-plugin-engine'}->{'vendor-os-name'}
+
+ return;
+}
+
+sub removalPhase
+{ # called while chrooted to the vendor-OS root in order to give the plugin
+ # a chance to uninstall no longer required files from the vendor-OS.
+ my $self = shift;
+ my $info = shift;
+
+ my $pluginRepoPath = $info->{'plugin-repo-path'};
+ # The folder where the stage1-plugin should store all files
+ # required by the corresponding stage3 runlevel script.
+ # As this method is being executed while chrooted into the vendor-OS,
+ # this path is relative to that root (i.e. directly usable).
+ my $pluginTempPath = $info->{'plugin-temp-path'};
+ # A temporary playground that will be cleaned up automatically.
+ # As this method is being executed while chrooted into the vendor-OS,
+ # this path is relative to that root (i.e. directly usable).
+
+ return;
+}
+
+1;
diff --git a/os-plugins/plugins/bindrivers/XX_bindrivers.sh b/os-plugins/plugins/bindrivers/XX_bindrivers.sh
new file mode 100644
index 00000000..9ac95a56
--- /dev/null
+++ b/os-plugins/plugins/bindrivers/XX_bindrivers.sh
@@ -0,0 +1,38 @@
+#! /bin/sh
+#
+# stage3 part of 'example' plugin - the runlevel script
+#
+# This basically is a runlevel script (just like you know them from 'init'),
+# whose purpose is to activate the plugin in stage3. The 'XX' at the beginning
+# of the filename will be replaced with a runlevel precedence number taken
+# from the configuration of the respective plugin. All plugin runlevel scripts
+# will be executed in the order of those precedence numbers.
+#
+# In order to activate the corresponding plugin, each runlevel script should:
+#
+# a) read the corresponding configuration file (in this case:
+# /initramfs/plugin-conf/example.conf)
+#
+# b) analyse the client (look at the available hardware) and decide what
+# needs to be done, taking into account the settings given in the config
+# file
+#
+# c) activate the plugin by copying/linking appropriate plugin-specific files
+# (in this case: from /mnt/opt/openslx/plugins/example/), load required kernel
+# modules and whatever else might be necessary.
+#
+# if you have any questions regarding the use of this file, please drop a mail
+# to: ot@openslx.com, or join the IRC-channel '#openslx' (on freenode).
+
+if [ -e /initramfs/plugin-conf/example.conf ]; then
+ . /initramfs/plugin-conf/example.conf
+ if [ $example_active -ne 0 ]; then
+ [ $DEBUGLEVEL -gt 0 ] && echo "executing the 'bindrivers' os-plugin ...";
+
+ # for this example plugin, we simply take a filename from the
+ # configuration and cat that file (output the smiley):
+ cat /mnt/opt/openslx/plugin-repo/example/$preferred_side
+
+ [ $DEBUGLEVEL -gt 0 ] && echo "done with 'bindrivers' os-plugin ...";
+ fi
+fi
diff --git a/os-plugins/plugins/vmchooser/OpenSLX/OSPlugin/vmchooser.pm b/os-plugins/plugins/vmchooser/OpenSLX/OSPlugin/vmchooser.pm
index c178700f..0ba9c17a 100644
--- a/os-plugins/plugins/vmchooser/OpenSLX/OSPlugin/vmchooser.pm
+++ b/os-plugins/plugins/vmchooser/OpenSLX/OSPlugin/vmchooser.pm
@@ -79,7 +79,8 @@ sub installationPhase
copyFile("$pluginBasePath/$file", "$pluginRepoPath/");
chmod 0755, "$pluginRepoPath/$file";
}
- copyFile("$pluginBasePath/default.desktop", "/usr/share/xsessions/");
+
+ #copyFile("$pluginBasePath/default.desktop", "/usr/share/xsessions/");
return;
}
diff --git a/os-plugins/plugins/vmchooser/XX_vmchooser.sh b/os-plugins/plugins/vmchooser/XX_vmchooser.sh
index a1a81c86..e7ec637c 100644
--- a/os-plugins/plugins/vmchooser/XX_vmchooser.sh
+++ b/os-plugins/plugins/vmchooser/XX_vmchooser.sh
@@ -5,6 +5,8 @@ if [ -e $CONFFILE ]; then
. $CONFFILE
if [ $vmchooser_active -ne 0 ]; then
[ $DEBUGLEVEL -gt 0 ] && echo "executing the 'vmchooser' os-plugin ...";
+ [ $DEBUGLEVEL -gt 0 ] && echo "copying default .desktop file ...";
+ cp /opt/openslx/plugin-repo/vmchooser/default.desktop /etc/X11/sessions/
[ $DEBUGLEVEL -gt 0 ] && echo "done with 'vmchooser' os-plugin ...";
fi
fi
diff --git a/os-plugins/plugins/vmchooser/files/xmlfilter.sh b/os-plugins/plugins/vmchooser/files/xmlfilter.sh
index 1d3e67c3..3de6e562 100755
--- a/os-plugins/plugins/vmchooser/files/xmlfilter.sh
+++ b/os-plugins/plugins/vmchooser/files/xmlfilter.sh
@@ -1,3 +1,25 @@
#!/bin/bash
+#
+# This script is a filter for the xml-files available
+#
+# currently:
+# - filter for slxgrp (which comes from /etc/machine-setup)
+#
-ls -1 /var/lib/vmware/*.xml
+
+if [ -f /etc/machine-setup ]; then
+ . /etc/machine-setup
+fi
+
+if [ -n $slxgrp ]; then
+ for FILE in $1/*.xml
+ do
+ # filter all xmls with pool-param not equal to slxgroup
+ if [ `grep "<pools param=\".*$slxgrp.*\"" $FILE | wc -l` -eq 1 ]; then
+ echo $FILE;
+ fi
+ done
+else
+ # if there is no pool set, just take all available xmls
+ ls -1 $1/*.xml
+fi