# This is the new configuration file for LedgerSMB. Eventually all system # configuration directives will go here, This will probably not fully replace # the ledgersmb.conf until 1.3, however. package LedgerSMB::Sysconfig; use LedgerSMB::Form; use Config::Std; use DBI qw(:sql_types); binmode STDOUT, ':utf8'; # For Win32, change $pathsep to ';'; $pathsep = ':'; $session = 'DB'; $logging = 0; # No logging on by default @io_lineitem_columns = qw(unit onhand sellprice discount linetotal); # Whitelist for redirect destination @scripts = ( 'aa.pl', 'admin.pl', 'am.pl', 'ap.pl', 'ar.pl', 'arap.pl', 'arapprn.pl', 'bp.pl', 'ca.pl', 'cp.pl', 'ct.pl', 'gl.pl', 'hr.pl', 'ic.pl', 'io.pl', 'ir.pl', 'is.pl', 'jc.pl', 'login.pl', 'menu.pl', 'oe.pl', 'pe.pl', 'pos.pl', 'ps.pl', 'pw.pl', 'rc.pl', 'rp.pl' ); # if you have latex installed set to 1 $latex = 1; # spool directory for batch printing $spool = "spool"; # path to user configuration files $userspath = "users"; # templates base directory $templates = "templates"; # Temporary files stored at" $tempdir = ( $ENV{TEMP} || '/tmp' ); # Backup path $backuppath = $tempdir; # member file $memberfile = "users/members"; # location of sendmail $sendmail = "/usr/sbin/sendmail -t"; # SMTP settings $smtphost = ''; $smtptimout = 60; # set language for login and admin $language = ""; # Maximum number of invoices that can be printed on a check $check_max_invoices = 5; # program to use for file compression $gzip = "gzip -S .gz"; # Path to the translation files $localepath = 'locale/po'; # available printers %printer = ( Laser => 'lpr -Plaser', Epson => 'lpr -PEpson', ); my %config; read_config( 'ledgersmb.conf' => %config ) or die; # We should clean this code up for 1.3 :-) Chris T. $logging = $config{''}{logging} if $config{''}{logging}; $check_max_invoices = $config{''}{check_max_invoices} if $config{''}{check_max_invoices}; $language = $config{''}{language} if $config{''}{language}; $session = $config{''}{session} if $config{''}{session}; $latex = $config{''}{latex} if $config{''}{latex}; if (ref $config{environment}{PATH} eq 'ARRAY') { $ENV{PATH} .= $pathsep . ( join $pathsep, @{ $config{environment}{PATH} } ); } elsif ($config{environment}{PATH}) { $ENV{PATH} .= $pathsep . $config{environment}{PATH}; } if (ref $config{environment}{PERL5LIB} eq 'ARRAY') { $ENV{PERL5LIB} .= ":" . ( join ':', @{ $config{environment}{PERL5LIB} } ); } elsif ($config{environment}{PERL5LIB}) { $ENV{PERL5LIB} .= ":" . $config{environment}{PERL5LIB}; } %printer = %{ $config{printers} } if $config{printers}; $localepath = $config{paths}{localepath} if $config{paths}{localepath}; $spool = $config{paths}{spool} if $config{paths}{spool}; $templates = $config{paths}{templates} if $config{paths}{templates}; $tempdir = $config{paths}{tempdir} if $config{paths}{tempdir}; $userspath = ( $config{paths}{userspath} ) ? $config{paths}{userspath} : $tempdir; $gzip = $config{programs}{gzip} if $config{programs}{gzip}; $sendmail = $config{mail}{sendmail} if $config{mail}{sendmail}; $smtphost = $config{mail}{smtphost} if $config{mail}{smtphost}; $smtptimeout = $config{mail}{smtptimeout} if $config{mail}{smtptimeout}; # We used to have a global dbconnect but have moved to single entries $globalDBhost = $config{globaldb}{DBhost} if $config{globaldb}{DBhost}; $globalDBport = $config{globaldb}{DBport} if $config{globaldb}{DBport}; $globalDBname = $config{globaldb}{DBname} if $config{globaldb}{DBname}; $globalDBUserName = $config{globaldb}{DBUserName} if $config{globaldb}{DBUserName}; $globalDBPassword = $config{globaldb}{DBPassword} if $config{globaldb}{DBPassword}; #putting this in an if clause for now so not to break other devel users if ( $config{globaldb}{DBname} ) { my $dbconnect = "dbi:Pg:dbname=$globalDBname host=$globalDBhost port=$globalDBport user=$globalDBUserName password=$globalDBPassword"; # for easier debugging $GLOBALDBH = DBI->connect($dbconnect); if ( !$GLOBALDBH ) { $form = new Form; $form->error("No GlobalDBH Configured or Could not Connect"); } $GLOBALDBH->{pg_enable_utf8} = 1; } # These lines prevent other apps in mod_perl from seeing the global db # connection info my $globalDBConnect = undef; my $globalUserName = undef; my $globalPassword = undef; 1;