4629e9423fc94a89c4a14f7e9054a4dc2674e62d
[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 sub get_show_bestbefore {
53   my ($self) = @_;
54   return $self->{data}->{show_bestbefore};
55 }
56
57 1;
58
59 __END__
60
61 =pod
62
63 =encoding utf8
64
65 =head1 NAME
66
67 SL::InstanceConfiguration - Provide instance-specific configuration data
68
69 =head1 SYNOPSIS
70
71 Lx-Office has two configuration levels: installation specific
72 (provided by the global variable C<%::lx_office_conf>) and instance
73 specific. The latter is provided by a global instance of this class,
74 C<$::instance_conf>.
75
76 =head1 FUNCTIONS
77
78 =over 4
79
80 =item C<new>
81
82 Creates a new instance. Does not read the configuration.
83
84 =item C<init>
85
86 Reads the configuration from the database. Returns C<$self>.
87
88 =item C<get_currencies>
89
90 Returns an array of configured currencies.
91
92 =item C<get_default_currency>
93
94 Returns the default currency or undef if no currency has been
95 configured.
96
97 =item C<get_accounting_method>
98
99 Returns the default accounting method, accrual or cash
100
101 =item C<get_inventory_system>
102
103 Returns the default inventory system, perpetual or periodic
104
105 =item C<get_profit_determination>
106
107 Returns the default profit determination method, balance or income
108
109 =item C<get_show_bestbefore>
110
111 Returns the default behavior for showing best before date, true or false
112
113 =back
114
115 =head1 BUGS
116
117 Updates to the I<defaults> table require that the instance
118 configuration is re-read. This has not been implemented yet.
119
120 =head1 AUTHOR
121
122 Moritz Bunkus E<lt>m.bunkus@linet-services.deE<gt>
123
124 =cut