# Copyright (c) 2007, 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/ # ----------------------------------------------------------------------------- # x11vnc.pm # ----------------------------------------------------------------------------- package OpenSLX::OSPlugin::x11vnc; use strict; use warnings; use base qw(OpenSLX::OSPlugin::Base); use OpenSLX::Basics; use OpenSLX::Utils; sub new { my $class = shift; my $self = { name => 'x11vnc', }; return bless $self, $class; } sub getInfo { my $self = shift; return { description => unshiftHereDoc(<<' End-of-Here'), enables x11vnc server (user or xorg) End-of-Here # waits for xorg to add configuration if needed precedence => 70, }; } sub getAttrInfo { my $self = shift; return { 'x11vnc::active' => { applies_to_systems => 1, applies_to_clients => 1, description => unshiftHereDoc(<<' End-of-Here'), should the 'x11vnc' plugin be executed during boot? End-of-Here content_regex => qr{^(0|1)$}, content_descr => '1 means active - 0 means inactive', default => '1', }, 'x11vnc::mode' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), set x11vnc to listen on Xorg user sessions (default), general access to the Xorg server (including displaymanager login) and console framebuffer. End-of-Here content_regex => qr{^(x11user|x11mod|fb)$}, content_descr => 'x11user for user, x11mod for access via Xorg module or fb', default => 'x11user', }, 'x11vnc::scale' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), scale screen size (e.g. as fraction 2/3 or as decimal 0.5) End-of-Here content_regex => undef, content_descr => undef, default => '', }, 'x11vnc::shared' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), by default x11vnc is always called with the -shared option End-of-Here content_regex => qr{^(yes|no|1|0)$}, content_descr => 'use 1 or yes to enable - 0 or no to disable', default => 'yes', }, 'x11vnc::force_viewonly' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), disable user interaction with vnc End-of-Here content_regex => qr{^(yes|no|1|0)$}, content_descr => 'use 1 or yes to enable - 0 or no to disable', default => 'no', }, 'x11vnc::auth_type' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), set authentication type of the vnc connection. rfbauth is available for x11user and fb only. End-of-Here content_regex => qr{^(passwd|rfbauth|none)$}, content_descr => 'choose: passwd, rfbauth, none', default => 'passwd', }, 'x11vnc::allowed_hosts' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), set allowed hosts (multiple hosts are seperated by semicolons, (simple) subnets are possible too e.g. "192.168.") End-of-Here content_regex => undef, content_descr => undef, default => '', }, 'x11vnc::force_localhost' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), force x11vnc to only accept local connections and only listen on the loopback device End-of-Here content_regex => qr{^(1|0|yes|no)$}, content_descr => 'use 1 or yes to enable - 0 or no to disable', default => 'no', }, 'x11vnc::pass' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), viewonly password (you can add multiple passwords seperated by semicolons, if you're using rfbauth only the first one is used) End-of-Here content_regex => undef, content_descr => undef, default => '', }, 'x11vnc::viewonlypass' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), viewonly password (you can add multiple passwords seperated by semicolons, disabled with rfb-auth) End-of-Here content_regex => undef, content_descr => undef, default => 'viewonly', }, 'x11vnc::logging' => { applies_to_systems => 1, applies_to_clients => 0, description => unshiftHereDoc(<<' End-of-Here'), enable logging End-of-Here content_regex => qr{^(1|0|yes|no)$}, content_descr => 'use 1 or yes to enable - 0 or no to disable', default => 'yes', }, }; } sub installationPhase { my $self = shift; my $info = shift; my $pluginRepositoryPath = $info->{'plugin-repo-path'}; my $pluginTempPath = $info->{'plugin-temp-path'}; my $openslxBasePath = $info->{'openslx-base-path'}; # should we distinguish between the two different packages!? # libvnc should be part of the xorg package!? (so no check needed) my $engine = $self->{'os-plugin-engine'}; if (!isInPath('x11vnc')) { $engine->installPackages( $engine->getInstallablePackagesForSelection('x11vnc') ); } else { vlog(3, "x11vnc is already installed"); } # get path of files we need to install my $pluginFilesPath = "$openslxBasePath/lib/plugins/$self->{'name'}/files"; my $script = $self->{distro}->fillRunlevelScript(); # copy all needed files now copyFile("$pluginFilesPath/x11vnc-init", "$pluginRepositoryPath"); spitFile("/etc/init.d/x11vnc", $script); chmod 0755, "/etc/init.d/x11vnc"; vlog(3, "install init file"); } sub removalPhase { my $self = shift; my $info = shift; } 1;