]> wagnertech.de Git - mfinanz.git/blobdiff - SL/InstanceConfiguration.pm
POD-Dokumentation aktualisiert
[mfinanz.git] / SL / InstanceConfiguration.pm
index d0b6b3a820e73841369362640d51a108905b9e70..084f0ac94bfdfd72c7de09b07bce4187223921a2 100644 (file)
@@ -2,189 +2,74 @@ package SL::InstanceConfiguration;
 
 use strict;
 
-use SL::DBUtils;
+use Carp;
+use SL::DBUtils ();
+use SL::System::Process;
 
-sub new {
-  my ($class) = @_;
+use parent qw(Rose::Object);
+use Rose::Object::MakeMethods::Generic (
+  'scalar --get_set_init' => [ qw(data currencies default_currency _table_currencies_exists crm_installed) ],
+);
 
-  return bless {}, $class;
+sub init_data {
+  return {} if !$::auth->client;
+  return SL::DBUtils::selectfirst_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT * FROM defaults|);
 }
 
-sub init {
-  my ($self) = @_;
-
-  $self->{data} = selectfirst_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT * FROM defaults|);
-
-  #To get all currencies and the default currency:
-  ($self->{data}->{curr}) = selectrow_query($::form, $::form->get_standard_dbh, qq|SELECT name AS curr FROM currencies WHERE id = (SELECT currency_id FROM defaults)|);
-  $self->{currencies}     = [ map { $_->{name} } selectall_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT name FROM currencies ORDER BY id|) ];
-
-  return $self;
-}
-
-sub get_default_currency {
-  my ($self) = @_;
-
-  return $self->{data}->{curr};
-}
-
-sub get_currencies {
-  my ($self) = @_;
-
-  return @{ $self->{currencies} };
-}
-
-sub get_accounting_method {
-  my ($self) = @_;
-  return $self->{data}->{accounting_method};
-}
-
-sub get_inventory_system {
-  my ($self) = @_;
-  return $self->{data}->{inventory_system};
-}
-
-sub get_profit_determination {
-  my ($self) = @_;
-  return $self->{data}->{profit_determination};
-}
-
-sub get_is_changeable {
-  my ($self) = @_;
-  return $self->{data}->{is_changeable};
-}
-
-sub get_ir_changeable {
-  my ($self) = @_;
-  return $self->{data}->{ir_changeable};
-}
-
-sub get_ar_changeable {
-  my ($self) = @_;
-  return $self->{data}->{ar_changeable};
-}
-
-sub get_ap_changeable {
-  my ($self) = @_;
-  return $self->{data}->{ap_changeable};
+sub init__table_currencies_exists {
+  return 0 if !$::auth->client;
+  return !!(SL::DBUtils::selectall_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT tablename FROM pg_tables WHERE (schemaname = 'public') AND (tablename = 'currencies')|))[0];
 }
 
-sub get_gl_changeable {
+sub init_currencies {
   my ($self) = @_;
-  return $self->{data}->{gl_changeable};
-}
-
-sub get_datev_check_on_sales_invoice {
-  my ($self) = @_;
-  return $self->{data}->{datev_check_on_sales_invoice};
-}
-
-sub get_datev_check_on_purchase_invoice {
-  my ($self) = @_;
-  return $self->{data}->{datev_check_on_purchase_invoice};
-}
-
-sub get_datev_check_on_ar_transaction {
-  my ($self) = @_;
-  return $self->{data}->{datev_check_on_ar_transaction};
-}
 
-sub get_datev_check_on_ap_transaction {
-  my ($self) = @_;
-  return $self->{data}->{datev_check_on_ap_transaction};
+  return [] if !$self->_table_currencies_exists;
+  return [ map { $_->{name} } SL::DBUtils::selectall_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT name FROM currencies ORDER BY id ASC|) ];
 }
 
-sub get_datev_check_on_gl_transaction {
+sub init_default_currency {
   my ($self) = @_;
-  return $self->{data}->{datev_check_on_gl_transaction};
-}
 
-sub get_show_bestbefore {
-  my ($self) = @_;
-  return $self->{data}->{show_bestbefore};
+  return undef if !$self->_table_currencies_exists || !$self->data->{currency_id};
+  return (SL::DBUtils::selectfirst_array_query($::form, $::form->get_standard_dbh, qq|SELECT name FROM currencies WHERE id = ?|, $self->data->{currency_id}))[0];
 }
 
-sub get_is_show_mark_as_paid {
-  my ($self) = @_;
-  return $self->{data}->{is_show_mark_as_paid};
+sub init_crm_installed {
+  return -f (SL::System::Process->exe_dir . '/crm/Changelog');
 }
 
-sub get_ir_show_mark_as_paid {
+sub reload {
   my ($self) = @_;
-  return $self->{data}->{ir_show_mark_as_paid};
-}
 
-sub get_ar_show_mark_as_paid {
-  my ($self) = @_;
-  return $self->{data}->{ar_show_mark_as_paid};
-}
+  delete @{ $self }{qw(data currencies default_currency)};
 
-sub get_ap_show_mark_as_paid {
-  my ($self) = @_;
-  return $self->{data}->{ap_show_mark_as_paid};
-}
-
-sub get_sales_order_show_delete {
-  my ($self) = @_;
-  return $self->{data}->{sales_order_show_delete};
-}
-
-sub get_purchase_order_show_delete {
-  my ($self) = @_;
-  return $self->{data}->{purchase_order_show_delete};
-}
-
-sub get_sales_delivery_order_show_delete {
-  my ($self) = @_;
-  return $self->{data}->{sales_delivery_order_show_delete};
-}
-
-sub get_purchase_delivery_order_show_delete {
-  my ($self) = @_;
-  return $self->{data}->{purchase_delivery_order_show_delete};
-}
-
-sub get_default_warehouse_id {
-  my ($self) = @_;
-  return ($self->{data}->{warehouse_id});
+  return $self;
 }
 
-sub get_default_bin_id {
-  my ($self) = @_;
-  return ($self->{data}->{bin_id});
-}
-sub get_default_warehouse_id_ignore_onhand {
+sub get_currencies {
   my ($self) = @_;
-  return ($self->{data}->{warehouse_id_ignore_onhand});
+  return @{ $self->currencies };
 }
 
-sub get_default_bin_id_ignore_onhand {
-  my ($self) = @_;
-  return ($self->{data}->{bin_id_ignore_onhand});
-}
+sub AUTOLOAD {
+  our $AUTOLOAD;
 
+  my $self   =  shift;
+  my $method =  $AUTOLOAD;
+  $method    =~ s/.*:://;
 
-sub get_transfer_default {
-  my ($self) = @_;
-  return ($self->{data}->{transfer_default});
-}
+  return if $method eq 'DESTROY';
 
-sub get_transfer_default_use_master_default_bin {
-  my ($self) = @_;
-  return ($self->{data}->{transfer_default_use_master_default_bin});
-}
+  if ($method =~ m/^get_/) {
+    $method = substr $method, 4;
+    return $self->data->{$method} if exists $self->data->{$method};
+    croak "Invalid method 'get_${method}'";
+  }
 
-sub get_transfer_default_ignore_onhand {
-  my ($self) = @_;
-  return ($self->{data}->{transfer_default_ignore_onhand});
+  croak "Invalid method '${method}'" if !$self->can($method);
+  return $self->$method(@_);
 }
-# currently unused - value is set via audit_control (Bücherkontrolle)
-sub get_max_future_booking_interval {
-  my ($self) = @_;
-  return ($self->{data}->{max_future_booking_interval});
-}
-
-
 
 1;
 
@@ -209,127 +94,10 @@ C<$::instance_conf>.
 
 =over 4
 
-=item C<new>
-
-Creates a new instance. Does not read the configuration.
-
-=item C<init>
-
-Reads the configuration from the database. Returns C<$self>.
-
 =item C<get_currencies>
 
 Returns an array of configured currencies.
 
-=item C<get_default_currency>
-
-Returns the default currency or undef if no currency has been
-configured.
-
-=item C<get_accounting_method>
-
-Returns the default accounting method, accrual or cash
-
-=item C<get_inventory_system>
-
-Returns the default inventory system, perpetual or periodic
-
-=item C<get_profit_determination>
-
-Returns the default profit determination method, balance or income
-
-
-=item C<get_is_changeable>
-
-=item C<get_ir_changeable>
-
-=item C<get_ar_changeable>
-
-=item C<get_ap_changeable>
-
-=item C<get_gl_changeable>
-
-Returns if and when these record types are changeable or deleteable after
-posting. 0 means never, 1 means always and 2 means on the same day.
-
-=item C<get_datev_check_on_sales_invoice>
-
-Returns true if datev check should be performed on sales invoices
-
-=item C<get_datev_check_on_purchase_invoice>
-
-Returns true if datev check should be performed on purchase invoices
-
-=item C<get_datev_check_on_ar_transaction>
-
-Returns true if datev check should be performed on ar transactions
-
-=item C<get_datev_check_on_ap_transaction>
-
-Returns true if datev check should be performed on ap transactions
-
-=item C<get_datev_check_on_gl_transaction>
-
-Returns true if datev check should be performed on gl transactions
-
-=item C<get_show_bestbefore>
-
-Returns the default behavior for showing best before date, true or false
-
-=item C<get_is_show_mark_as_paid>
-
-=item C<get_ir_show_mark_as_paid>
-
-=item C<get_ar_show_mark_as_paid>
-
-=item C<get_ap_show_mark_as_paid>
-
-Returns the default behavior for showing the mark as paid button for the
-corresponding record type (true or false).
-
-=item C<get_sales_order_show_delete>
-
-=item C<get_purchase_order_show_delete>
-
-=item C<get_sales_delivery_order_show_delete>
-
-=item C<get_purchase_delivery_order_show_delete>
-
-Returns the default behavior for showing the delete button for the
-corresponding record type (true or false).
-
-=item C<get_default_warehouse_id>
-
-Returns the default warehouse_id
-
-=item C<get_default_bin_id>
-
-Returns the default bin_id
-
-=item C<get_default_warehouse_id_ignore_onhand>
-
-Returns the default warehouse_id for transfers without checking the
-current stock quantity
-
-=item C<get_default_bin_id_ignore_onhand>
-
-Returns the default bin_id for transfers without checking the.
-current stock quantity
-
-
-
-=item C<get_transfer_default>
-
-=item C<get_transfer_default_use_master_default_bin>
-
-=item C<get_transfer_default_ignore_onhand>
-
-Returns the default behavior for the transfer out default feature (true or false)
-
-=item C<get_max_future_booking_interval>
-
-Returns the maximum interval value for future bookings
-
 =back
 
 =head1 BUGS