Shopware6: Optionalen Proxy erlauben und Protokoll http oder https initialisieren
[kivitendo-erp.git] / SL / DB / Shop.pm
1 # This file has been auto-generated only because it didn't exist.
2 # Feel free to modify it at will; it will not be overwritten automatically.
3
4 package SL::DB::Shop;
5
6 use strict;
7
8 use SL::DB::MetaSetup::Shop;
9 use SL::DB::Manager::Shop;
10 use SL::DB::Helper::ActsAsList;
11 use SL::Locale::String qw(t8);
12
13 __PACKAGE__->meta->initialize;
14
15 sub validate {
16   my ($self) = @_;
17
18   my @errors;
19   # critical checks
20   push @errors, $::locale->text('The description is missing.') unless $self->{description};
21   push @errors, $::locale->text('The path is missing.')        unless $self->{path};
22   push @errors, $::locale->text('The Host Name is missing')    unless $self->{server};
23   push @errors, $::locale->text('The Host Name seems invalid') unless $self->{server} =~ m/[0-9A-Za-z].\.[0-9A-Za-z]/;
24   push @errors, $::locale->text('The Proxy Name seems invalid') unless $self->{proxy} =~ m/[0-9A-Za-z].\.[0-9A-Za-z]/;
25   push @errors, $::locale->text('Orders to fetch neeeds a positive Integer')
26                                                                unless $self->{orders_to_fetch} > 0;
27
28   # not yet implemented checks
29   push @errors, $::locale->text('Transaction Description is not yet implemented')    if $self->{transaction_description};
30   if ($self->{connector} eq 'shopware6') {
31     push @errors, $::locale->text('Shipping cost article is not implemented')        if $self->{shipping_costs_parts_id};
32     push @errors, $::locale->text('Fetch from last order number is not implemented') if $self->{last_order_number};
33   } else {
34     push @errors, $::locale->text('Use Long Description from Parts is only for Shopware6 implemented')
35       if $self->{use_part_longdescription};
36   }
37   return @errors;
38 }
39
40 sub shops_dd {
41   my ( $self ) = @_;
42
43   my @shops_dd = ( { title => t8("all") ,   value =>'' } );
44   my $shops = SL::DB::Manager::Shop->get_all( where => [ obsolete => 0 ] );
45   my @tmp = map { { title => $_->{description}, value => $_->{id} } } @{ $shops } ;
46   push @shops_dd, @tmp;
47   return \@shops_dd;
48 }
49
50 1;
51
52 __END__
53
54 =pod
55
56 =encoding utf-8
57
58 =head1 NAME
59
60 SL::DB::Shop - Model for the 'shops' table
61
62 =head1 SYNOPSIS
63
64 This is a standard Rose::DB::Object based model and can be used as one.
65
66 =head1 METHODS
67
68 =over 4
69
70 =item C<validate>
71
72 Returns an error if the shop description is missing
73
74 =item C<shops_dd>
75
76 Returns an array of hashes for dropdowns in filters
77
78 =back
79
80 =head1 AUTHORS
81
82 Werner Hahn E<lt>wh@futureworldsearch.netE<gt>
83
84 G. Richardson E<lt>grichardson@kivitendo-premium.deE<gt>
85
86 =cut