XML basiertes Menue, siehe Bug #771
[kivitendo-erp.git] / bin / mozilla / ustva.pl
index 2368545..4229d24 100644 (file)
@@ -24,7 +24,8 @@
 # German Tax authority Module and later ELSTER Interface
 #======================================================================
 
-require "$form->{path}/arap.pl";
+require "bin/mozilla/arap.pl";
+require "bin/mozilla/common.pl";
 
 #use strict;
 #no strict 'refs';
@@ -88,7 +89,7 @@ sub report {
   $form->header;
 
   # Einlesen der Finanzamtdaten
-  &get_config($userspath, 'finanzamt.ini');
+  USTVA->get_config($userspath, 'finanzamt.ini');
 
   # Hier Einlesen der user-config
   # steuernummer entfernt für prerelease
@@ -112,7 +113,7 @@ sub report {
 
   my $company_given = ($form->{company} ne '') 
     ? qq|<h3>$form->{company}</h3>\n|
-    : qq|<a href=am.pl?path=$form->{path}&action=config|
+    : qq|<a href=am.pl?action=config|
       . qq|&level=Programm--Preferences&login=$form->{login}|
       . qq|&password=$form->{password}>| 
       . $locale->text('No Company Name given') . qq|!</a><br>|;
@@ -138,7 +139,7 @@ sub report {
     ? qq|$form->{co_street}<br>|
         . qq|$form->{co_street1}<br>|
         . qq|$form->{co_zip} $form->{co_city}|
-    : qq|<a href=am.pl?path=$form->{path}&action=config|
+    : qq|<a href=am.pl?action=config|
         . qq|&level=Programm--Preferences&login=$form->{login}|
         . qq|&password=$form->{password}>| 
         . $locale->text('No Company Address given') 
@@ -151,7 +152,7 @@ sub report {
 
   my $taxnumber_given = ($form->{steuernummer} ne '')
     ? qq|$form->{steuernummer}|
-    : qq|<a href="ustva.pl?path=$form->{path}&action="config_step1"|
+    : qq|<a href="ustva.pl?action="config_step1"|
       . qq|&level=Programm--Finanzamteinstellungen&login=$form->{login}|
       . qq|&password=$form->{password}">Keine Steuernummer hinterlegt!|
       . qq|</a><br>|;
@@ -196,12 +197,16 @@ sub report {
     }
   ];
  
+  # Which COA is in use? 
   
+  USTVA->get_coa($form, $myconfig);
+
   my $template_ref = {
     openings         => $openings,  
     company_given    => $company_given,
     address_given    => $address_given,     
     taxnumber_given  => $taxnumber_given,
+    taxnumber        => $myconfig->{taxnumber},
     select_year      => $select_year,      
     period_local     => $period_local,
     method_local     => $method_local,
@@ -209,6 +214,7 @@ sub report {
     checkbox_kz_10   => $checkbox_kz_10,
     tax_office_banks => $tax_office_banks_ref,    
     select_options   => &show_options,    
+
   };
   
   print($form->parse_html_template('ustva/report', $template_ref));
@@ -241,7 +247,7 @@ sub show {
   #&generate_ustva();
   no strict 'refs';
   $lxdebug->leave_sub();
-  &{ $form->{nextsub} };
+  call_sub($form->{"nextsub"});
   use strict 'refs';
 }
 
@@ -528,10 +534,9 @@ sub show_options {
 sub generate_ustva {
   $lxdebug->enter_sub();
 
-  # Aufruf von get_config aus bin/mozilla/ustva.pl zum
-  # Einlesen der Finanzamtdaten aus finanzamt.ini
+  # Aufruf von get_config zum Einlesen der Finanzamtdaten aus finanzamt.ini
 
-  get_config($userspath, 'finanzamt.ini');
+  USTVA->get_config($userspath, 'finanzamt.ini');
 
   # init some form vars
   my @anmeldungszeitraum =
@@ -740,129 +745,177 @@ sub generate_ustva {
     $form->{co_city} =~ s/\\n//g;
   }
 
+  ################################
   #
-  # Outputformat specific customisation's
+  # Nation specific customisations
   #
+  ################################
+  
+  # Germany
+  
+  if ( $form->{coa} eq 'Germany-DATEV-SKR03EU' or $form->{coa} eq 'Germany-DATEV-SKR04EU') {
+      
+    #
+    # Outputformat specific customisation's
+    #
 
-  my @category_cent = qw(
-    511 861 36   80   971  931  98   96   53   74
-    85  65  66   61   62   67   63   64   59   69 
-    39  83  811  891  Z43  Z45  Z53  Z62  Z65  Z67
+    my @category_cent = USTVA->report_variables({
+        myconfig    => \%myconfig,
+        form        => $form,
+        type        => '',
+        attribute   => 'position',
+        dec_places  => '2',
+    });
     
-  );
-
-  my @category_euro = qw(
-    41 44 49 43 48 51 86 35 77 76 91 89
-    97 93 95 94 42 60 45 52 73 84 81 
-  );
+    push @category_cent, qw(83  Z43  Z45  Z53  Z62  Z65  Z67);
 
-  if ( $form->{format} eq 'pdf' or $form->{format} eq 'postscript') {
+    my @category_euro = USTVA->report_variables({
+        myconfig    => \%myconfig,
+        form        => $form,
+        type        => '',
+        attribute   => 'position',
+        dec_places  => '0',
+    });
 
-    $form->{IN} = "$form->{type}-$form->{year}.tex";
-    $form->{padding} = "~~";
-    $form->{bold}    = "\textbf{";
-    $form->{endbold} = "}";
-    $form->{br}      = '\\\\';
+    $form->{id} = [];
+    $form->{amount} = [];
 
-    # Zahlenformatierung für Latex USTVA Formulare
+    if ( $form->{format} eq 'pdf' or $form->{format} eq 'postscript') {
 
-    foreach my $number (@category_euro) {
-      $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '0', '');
-    }
+      $form->{IN} = "$form->{type}-$form->{year}.tex";
+      $form->{padding} = "~~";
+      $form->{bold}    = "\textbf{";
+      $form->{endbold} = "}";
+      $form->{br}      = '\\\\';
 
-    my ${decimal_comma} = ( $myconfig{numberformat} eq '1.000,00'
-         or $myconfig{numberformat} eq '1000,00' ) ? ',':'.';
+      # Zahlenformatierung für Latex USTVA Formulare
 
-    foreach my $number (@category_cent) {
-      $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '2', '');
-      $form->{$number} =~ s/${decimal_comma}/~~/g;
-    }
+      foreach my $number (@category_euro) {
+        $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '0', '');
+      }
 
-  } elsif ( $form->{format} eq 'html') { # Formatierungen für HTML Ausgabe
+      my ${decimal_comma} = ( $myconfig{numberformat} eq '1.000,00'
+           or $myconfig{numberformat} eq '1000,00' ) ? ',':'.';
 
-    $form->{IN} = $form->{type} . '.html';
-    $form->{padding} = "&nbsp;&nbsp;";
-    $form->{bold}    = "<b>";
-    $form->{endbold} = "</b>";
-    $form->{br}      = "<br>";
-    $form->{address} =~ s/\\n/\n/g;
+      foreach my $number (@category_cent) {
+        $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '2', '');
+        $form->{$number} =~ s/${decimal_comma}/~~/g;
+      }
 
-    foreach $number (@category_cent) {
-      $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '2', '0');
-    }
-    
-    foreach $number (@category_euro) {
-      $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '0', '0');
-    }
+    } elsif ( $form->{format} eq 'html') { # Formatierungen für HTML Ausgabe
 
-  } elsif ( $form->{format} eq 'elsterwinston' ) {
+      $form->{IN} = $form->{type} . '.html';
+      $form->{padding} = "&nbsp;&nbsp;";
+      $form->{bold}    = "<b>";
+      $form->{endbold} = "</b>";
+      $form->{br}      = "<br>";
+      $form->{address} =~ s/\\n/\n/g;
 
-    $form->{IN} = 'winston.xml';
-    
-    #
-    # Build Winston filename
-    #
-    
-    my $file = 'U';     # 1. char 'U' = USTVA
-    $file .= $form->{period};
-    #4. and 5. char = year modulo 100
-    $file .= sprintf("%02d", $form->{year} % 100);
-    #6. to 18. char = Elstersteuernummer
-    #Beispiel: Steuernummer in Bayern
-    #111/222/33334 ergibt für UStVA Jan 2004: U01049111022233334
-    $file .= $form->{elsterFFFF};
-    $file .= $form->{elstersteuernummer};
-    #file suffix
-    $file .= '.xml';
-    $form->{tmpfile} = "$userspath/$file";
-
-    $form->{attachment_filename} = "$file";
-    # Zahlenformatierung für Winston
+      foreach $number (@category_cent) {
+        $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '2', '0');
+      }
+      
+      foreach $number (@category_euro) {
+        $form->{$number} = $form->format_amount(\%myconfig, $form->{$number}, '0', '0');
+      }
 
-    my $temp_numberformat = $myconfig{numberformat};
+    } elsif ( $form->{format} eq 'elsterwinston' ) {
 
-    # Numberformat must be '1000.00' for Winston
+      $form->{IN} = 'winston.xml';
+      
+      #
+      # Build Winston filename
+      #
+      
+      my $file = 'U';     # 1. char 'U' = USTVA
+      $file .= $form->{period};
+      #4. and 5. char = year modulo 100
+      $file .= sprintf("%02d", $form->{year} % 100);
+      #6. to 18. char = Elstersteuernummer
+      #Beispiel: Steuernummer in Bayern
+      #111/222/33334 ergibt für UStVA Jan 2004: U01049111022233334
+      $file .= $form->{elsterFFFF};
+      $file .= $form->{elstersteuernummer};
+      #file suffix
+      $file .= '.xml';
+      $file =~ s|.*/||;
+      $form->{tmpfile} = "$userspath/$file";
+
+      $form->{attachment_filename} = $file;
+   
+      # Zahlenformatierung für Winston
 
-    $myconfig{numberformat} = '1000.00';
+      my $temp_numberformat = $myconfig{numberformat};
 
-    foreach my $number (@category_cent) {
-      $form->{$number} = ( $form->{$number} !=0 ) ? $form->format_amount(\%myconfig, $form->{$number}, '2', '') : '';
-    }
-    
-    foreach my $number (@category_euro) {
-      $form->{$number} = ( $form->{$number} !=0 ) ? $form->format_amount(\%myconfig, $form->{$number}, '0', '') : '';
-    }
-    # Re-set Numberformat
-    $myconfig{numberformat} = $temp_numberformat;
+      # Numberformat must be '1000.00' for Winston
 
-  }
+      $myconfig{numberformat} = '1000.00';
 
-  elsif ( $form->{format} eq 'elstertaxbird' ) {
+      foreach my $number (@category_cent) {
+        $form->{$number} = ( $form->{$number} !=0 ) ? $form->format_amount(\%myconfig, $form->{$number}, '2', '') : '';
+      }
+      
+      foreach my $number (@category_euro) {
+        $form->{$number} = ( $form->{$number} !=0 ) ? $form->format_amount(\%myconfig, $form->{$number}, '0', '') : '';
+      }
+      # Re-set Numberformat
+      $myconfig{numberformat} = $temp_numberformat;
 
-    # Define serveral filenames
-    $form->{IN} = 'taxbird.txb';
+      # push Kennziffern to <%foreach Array fo easyer
+      # output in xml format. Thx to Moritz.
+      my %winston_id_for = (
+         # No Winston remap?!
+      );
 
-    $form->{attachment_filename} = "USTVA-" . $form->{period} 
-    . sprintf("%02d", $form->{year} % 100) . ".txb";
-    
-    $form->{tmpfile} = "$userspath/" . $form->{attachment_filename};
-
-    # TODO: set Output to UTF-8 or system Preference
-    #$form->{"iconv"} = Text::Iconv->new($myconfig{dbcharset}, "UTF-8");
-    #my $iconv = $self->{"iconv"};
-    #$iconv->convert($variable);
-
-    if ($form->{period} =~ /^[4]\d$/ ){
-      my %periods = ( # Lx => taxbird
-                   '41' => '12',
-                   '42' => '13',
-                   '43' => '14',
-                   '44' => '15',
-                 );
-    
-      foreach my $quarter ( keys %periods ) {
-        $form->{taxbird_period} = $periods{$quarter} if ( $form->{period} eq $quarter);
+      foreach my $kennziffer (@category_cent, @category_euro) {
+      
+        next if ( $kennziffer =~ m/Z\d\d/);
+        next if (   $form->{$kennziffer} == 0 );
+        
+        if (defined $winston_id_for{$kennziffer} ) {
+          push(@{ $form->{id}}, $winston_id_for{$kennziffer});
+        } else {
+          push(@{ $form->{id}}, "Kz$kennziffer"); 
+        }
+        push(@{ $form->{amount}}, $form->{$kennziffer});
+      }    
+
+    } elsif ( $form->{format} eq 'elstertaxbird' ) {
+
+      # Define serveral filenames
+      $form->{IN} = 'taxbird.txb';
+
+      $form->{attachment_filename} = "USTVA-" . $form->{period} 
+      . sprintf("%02d", $form->{year} % 100) . ".txb";
+      
+      $form->{attachment_filename} =~ s|.*/||;
+      $form->{tmpfile} = "$userspath/" . $form->{attachment_filename};
+
+      # TODO: set Output to UTF-8 or system Preference
+      #$form->{"iconv"} = Text::Iconv->new($myconfig{dbcharset}, "UTF-8");
+      #my $iconv = $self->{"iconv"};
+      #$iconv->convert($variable);
+      if ($form->{period} =~ /^[4]\d$/ ){
+        my %periods = ( # Lx => taxbird
+                     '41' => '12',
+                     '42' => '13',
+                     '43' => '14',
+                     '44' => '15',
+                   );
+      
+        foreach my $quarter ( keys %periods ) {
+          $form->{taxbird_period} = $periods{$quarter} if ( $form->{period} eq $quarter);
+        }
+      } elsif ($form->{period} =~ /^\d+$/ ) {
+        $form->{period} =~ s/^0//g;
+        my $period = $form->{period};
+        $period * 1;
+        $period--;
+        $form->{period} = $period;
+      } else {
+        $form->header;
+        USTVA::error( $locale->text('Wrong Period' ));
+        exit(0);
       }
       
       my %lands = ( # Lx => taxbird # TODO: besser als array...
@@ -883,7 +936,6 @@ sub generate_ustva {
                   'Schleswig Holstein'     => '14',
                   'Thüringen'              => '15',
             );
-
       foreach my $land ( keys %lands ){
         $form->{taxbird_land_nr} = $lands{$land} if ($form->{elsterland} eq $land );
       }
@@ -898,15 +950,13 @@ sub generate_ustva {
       $form->{co_phone} =~ s/\s//g;
       
        $form->{taxbird_steuernummer} = $form->{steuernummer};
-#      $form->{taxbird_steuernummer} =~ s/\D//g;
+      #      $form->{taxbird_steuernummer} =~ s/\D//g;
       $form->{taxbird_steuernummer} =~ s/\///; # ersten Querstrich ersetzen
       
       # Numberformatting for Taxbird
       my $temp_numberformat = $myconfig{numberformat};
-
       # Numberformat must be '1000,00' for Taxbird ?!
       $myconfig{numberformat} = '1000,00';
-
       foreach my $number (@category_cent) {
         $form->{$number} = ( $form->{$number} !=0 ) ? $form->format_amount(\%myconfig, $form->{$number}, '2', '') : '';
       }
@@ -917,29 +967,89 @@ sub generate_ustva {
       # Re-set Numberformat
       $myconfig{numberformat} = $temp_numberformat;
       
-    } elsif ($form->{period} =~ /^\d+$/ ) {
-      $form->{period} =~ s/^0//g;
-      my $period = $form->{period};
-      $period * 1;
-      $period--;
-      $form->{period} = $period;
-    } else {
+      # push Kennziffern to <%foreach Array fo easyer
+      # output in xml format. Thx to Moritz.
+      my %taxbird_id_for = (
+           
+          '511'  =>  'Kz51-calc',
+          '861'  =>  'Kz86-calc',
+          '971'  =>  'Kz97-calc',
+          '931'  =>  'Kz93-calc',
+          '811'  =>  'Kz81-calc',
+          '891'  =>  'Kz89-calc',
+          'Z45'  =>  'uebertrag',
+          'Z53'  =>  'ust-sum',
+          'Z62'  =>  'ust-minus-vost',
+          'Z65'  =>  'ust-sum+69',
+          'Z67'  =>  'ust-vz',
+      );
+            
+      
+      for my $kennziffer (@category_cent, @category_euro) {
+
+        next if ($kennziffer eq 'Z43');
+
+        if ($form->{$kennziffer} != 0){
+          if (defined $taxbird_id_for{$kennziffer}) {
+            push(@{ $form->{id}}, $taxbird_id_for{$kennziffer});
+          } else {
+            push(@{ $form->{id}}, "Kz$kennziffer"); 
+          }
+          push(@{ $form->{amount}}, $form->{$kennziffer});
+        }
+      }    
+      
+    } elsif ( $form->{format} eq '' ){ # No format error.
+      $form->header;
+      USTVA::error( $locale->text('Application Error. No Format given' ) . "!");
+      exit(0);
+   
+    } else { # All other Formats are wrong
       $form->header;
-      USTVA::error( $locale->text('Wrong Period' ));
+      USTVA::error( $locale->text('Application Error. Wrong Format') . ": " . $form->{format} );
       exit(0);
     }
-    
-  } elsif ( $form->{format} eq '' ){ # No format error.
-    $form->header;
-    USTVA::error( $locale->text('Application Error. No Format given' ) . "!");
-    exit(0);
-  } else { # All other Formats are wrong
-    $form->header;
-    USTVA::error( $locale->text('Application Error. Wrong Format') . ": " . $form->{format} );
-    exit(0);
-  }
 
+  
+  } else  # Outputformat for generic output
+  {
+
+    my @category_cent = USTVA->report_variables({
+        myconfig    => \%myconfig,
+        form        => $form,
+        type        => '',
+        attribute   => 'position',
+        dec_places  => '2',
+    });
+
+    my @category_euro = USTVA->report_variables({
+        myconfig    => \%myconfig,
+        form        => $form,
+        type        => '',
+        attribute   => 'position',
+        dec_places  => '0',
+    });
+
+    $form->{"Watchdog::USTVA"} = 1;
+    $form->{USTVA} = [];
+
+    if ( $form->{format} eq 'generic') { # Formatierungen für HTML Ausgabe
+      
+      my $rec_ref = {};
+      for my $kennziffer (@category_cent, @category_euro) {
+        $rec_ref = {};
+        $rec_ref->{id} = $kennziffer;
+        $rec_ref->{amount} = $form->format_amount(\%myconfig, $form->{$kennziffer}, 2, '0');
+        
+        $lxdebug->message($LXDebug::DEBUG, "Kennziffer $kennziffer: '$form->{$kennziffer}'" );
+        $lxdebug->dump($LXDebug::DEBUG, $rec_ref );
+        push @ { $form->{USTVA} }, $rec_ref;
+      }
+      
+    }
+
+  }
+  
   if ( $form->{period} eq '13' and $form->{format} ne 'html') {
     $form->header;
     USTVA::info(
@@ -951,7 +1061,22 @@ sub generate_ustva {
   $form->{templates} = $myconfig{templates};
   $form->{templates} = "doc" if ( $form->{type} eq 'help' );
 
-  $form->parse_template(\%myconfig, $userspath);
+  if ($form->{format} eq 'generic'){
+
+    $form->header();
+
+    $template_ref = {
+        taxnumber => $myconfig{taxnumber},
+    };
+
+    print($form->parse_html_template2('ustva/generic_taxreport', $template_ref));
+
+  } else
+  { 
+
+    $form->parse_template(\%myconfig, $userspath);
+
+  }
 
   $lxdebug->leave_sub();
 }
@@ -962,7 +1087,7 @@ sub config_step1 {
   # edit all taxauthority prefs
 
   $form->header;
-  &get_config($userspath, 'finanzamt.ini');
+  USTVA->get_config($userspath, 'finanzamt.ini');
 
   my $land = $form->{elsterland};
   my $amt  = $form->{elsterFFFF};
@@ -972,7 +1097,6 @@ sub config_step1 {
     $callback =  qq|$form->{cbscript}|
                 .qq|?action="config_step1"|
                 .qq|&login="$form->{cblogin}"|
-                .qq|&path="$form->{cbpath}"|
                 .qq|&root="$form->{cbroot}"|
                 .qq|&rpw="$form->{cbrpw}"|;
   }
@@ -1009,8 +1133,7 @@ sub config_step1 {
     FA_BLZ_2            FA_Kontonummer_2  FA_Bankbezeichnung_oertlich
     FA_Oeffnungszeiten  FA_Email          FA_Internet
     steuernummer        elsterland        elstersteuernummer
-    elsterFFFF          path              login
-    password
+    elsterFFFF          login             password
   );
 
   foreach my $variable (@_hidden_form_variables) {
@@ -1018,6 +1141,10 @@ sub config_step1 {
         { 'variable' => $variable, 'value' => $form->{$variable} };
   }
 
+# Which COA is in use? 
+  
+  USTVA->get_coa($form, \%myconfig);
+
   # hä? kann die weg?
   my $steuernummer_new = '';
 
@@ -1051,7 +1178,7 @@ sub config_step2 {
   my $elster_amt         = '';
   my $elsterFFFF         = '';
   my $elstersteuernummer = '';
-  &get_config($userspath, 'finanzamt.ini')
+  USTVA->get_config($userspath, 'finanzamt.ini')
     if ($form->{saved} eq $locale->text('saved'));
 
   # Auf Übergabefehler checken
@@ -1154,14 +1281,12 @@ sub config_step2 {
     FA_steuerberater_city   FA_steuerberater_tel
     FA_voranmeld            method
     FA_dauerfrist           FA_71 
-    elster                  path 
+    elster                  
     login                   password 
     type                    elster_init 
     saved                   callback
   );
 
-
-
   foreach my $variable (@_hidden_form_variables) {
     push @{ $_hidden_variables_ref}, 
         { 'variable' => $variable, 'value' => $form->{$variable} };
@@ -1218,42 +1343,11 @@ sub create_steuernummer {
   $lxdebug->leave_sub();
 }
 
-sub get_config {
-  $lxdebug->enter_sub();
-
-  my ($userpath, $filename) = @_;
-  my ($key,      $value)    = '';
-  open(FACONF, "$userpath/$form->{login}_$filename")
-    or    #falls Datei nicht vorhanden ist
-    sub {
-    open(FANEW, ">$userpath/$form->{login}_$filename")
-      or $form->error("$userpath/$filename : $!");
-    close FANEW;
-    open(FACONF, "$userpath/$form->{login}_$filename")
-      or $form->error("$userpath/$form->{username}_$filename : $!");
-    };
-  while (<FACONF>) {
-    last if /^\[/;
-    next if /^(#|\s)/;
-
-    # remove comments
-    s/\s#.*//g;
-
-    # remove any trailing whitespace
-    s/^\s*(.*?)\s*$/$1/;
-    ($key, $value) = split /=/, $_, 2;
-
-    $form->{$key} = "$value";
-
-  }
-  close FACONF;
-
-  $lxdebug->leave_sub();
-}
-
 sub save {
   $lxdebug->enter_sub();
+
   my $filename = "$form->{login}_$form->{filename}";
+  $filename =~ s|.*/||;
 
   #zuerst die steuernummer aus den part, parts_X_Y und delimiter herstellen
   create_steuernummer();
@@ -1279,27 +1373,29 @@ sub save {
 
   # Hier kommt dann die Plausibilitätsprüfung der ELSTERSteuernummer
   if ($form->{elstersteuernummer} ne '000000000') {
+    
     $form->{elster} = '1';
-    open(CONF, ">$userspath/$filename") or $form->error("$filename : $!");
+    
+    open my $ustvaconfig, ">", "$userspath/$filename" or $form->error("$filename : $!");
 
     # create the config file
-    print CONF qq|# Configuration file for USTVA\n\n|;
+    print {$ustvaconfig} qq|# Configuration file for USTVA\n\n|;
     my $key = '';
     foreach $key (sort @config) {
       $form->{$key} =~ s/\\/\\\\/g;
       # strip M
       $form->{$key} =~ s/\r\n/\n/g;
 
-      print CONF qq|$key=|;
+      print {$ustvaconfig} qq|$key=|;
       if ($form->{$key} ne 'Y') {
-        print CONF qq|$form->{$key}\n|;
+        print {$ustvaconfig} qq|$form->{$key}\n|;
       }
       if ($form->{$key} eq 'Y') {
-        print CONF qq|checked \n|;
+        print {$ustvaconfig} qq|checked \n|;
       }
     }
-    print CONF qq|\n\n|;
-    close CONF;
+    print {$ustvaconfig} qq|\n\n|;
+    close $ustvaconfig;
     $form->{saved} = $locale->text('saved');
 
   } else {
@@ -1317,14 +1413,14 @@ sub continue {
 
   # allow Symbolic references just here:
   no strict 'refs';
-  &{ $form->{nextsub} };
+  call_sub($form->{"nextsub"});
   use strict 'refs';
   $lxdebug->leave_sub();
 }
 
 sub back {
   $lxdebug->enter_sub();
-  &{ $form->{lastsub} };
+  call_sub($form->{"lastsub"});
   $lxdebug->leave_sub();
 }