47cdd0e191773e5d5b4ef8c17a9f8de39489f495
[kivitendo-erp.git] / SL / InstanceConfiguration.pm
1 package SL::InstanceConfiguration;
2
3 use strict;
4
5 use SL::DBUtils;
6
7 sub new {
8   my ($class) = @_;
9
10   return bless {}, $class;
11 }
12
13 sub init {
14   my ($self) = @_;
15
16   $self->{data} = selectfirst_hashref_query($::form, $::form->get_standard_dbh, qq|SELECT * FROM defaults|);
17
18   my $curr            =  $self->{data}->{curr} || '';
19   $curr               =~ s/\s+//g;
20   $self->{currencies} =  [ split m/:/, $curr ];
21
22   return $self;
23 }
24
25 sub get_default_currency {
26   my ($self) = @_;
27
28   return ($self->get_currencies)[0];
29 }
30
31 sub get_currencies {
32   my ($self) = @_;
33
34   return $self->{currencies} ? @{ $self->{currencies} } : ();
35 }
36
37 sub get_accounting_method {
38   my ($self) = @_;
39   return $self->{data}->{accounting_method};
40 }
41
42 sub get_inventory_system {
43   my ($self) = @_;
44   return $self->{data}->{inventory_system};
45 }
46
47 sub get_profit_determination {
48   my ($self) = @_;
49   return $self->{data}->{profit_determination};
50 }
51
52 1;
53
54 __END__
55
56 =pod
57
58 =encoding utf8
59
60 =head1 NAME
61
62 SL::InstanceConfiguration - Provide instance-specific configuration data
63
64 =head1 SYNOPSIS
65
66 Lx-Office has two configuration levels: installation specific
67 (provided by the global variable C<%::lxoffice_conf>) and instance
68 specific. The latter is provided by a global instance of this class,
69 C<$::instance_conf>.
70
71 =head1 FUNCTIONS
72
73 =over 4
74
75 =item C<new>
76
77 Creates a new instance. Does not read the configuration.
78
79 =item C<init>
80
81 Reads the configuration from the database. Returns C<$self>.
82
83 =item C<get_currencies>
84
85 Returns an array of configured currencies.
86
87 =item C<get_default_currency>
88
89 Returns the default currency or undef if no currency has been
90 configured.
91
92 =item C<get_accounting_method>
93
94 Returns the default accounting method, accrual or cash
95
96 =item C<get_inventory_system>
97
98 Returns the default inventory system, perpetual or periodic
99
100 =item C<get_profit_determination>
101
102 Returns the default profit determination method, balance or income
103
104 =back
105
106 =head1 BUGS
107
108 Updates to the I<defaults> table require that the instance
109 configuration is re-read. This has not been implemented yet.
110
111 =head1 AUTHOR
112
113 Moritz Bunkus E<lt>m.bunkus@linet-services.deE<gt>
114
115 =cut