1 |
joko |
1.1 |
## ------------------------------------------------------------------------ |
2 |
|
|
## $Id$ |
3 |
|
|
## ------------------------------------------------------------------------ |
4 |
|
|
## $Log$ |
5 |
|
|
## ------------------------------------------------------------------------ |
6 |
|
|
|
7 |
|
|
|
8 |
|
|
package Data::Storage::Handler::MAPI; |
9 |
|
|
|
10 |
|
|
use strict; |
11 |
|
|
use warnings; |
12 |
|
|
|
13 |
|
|
use base qw( |
14 |
|
|
Data::Storage::Handler |
15 |
|
|
Data::Storage::Handler::Abstract |
16 |
|
|
DesignPattern::Bridge |
17 |
|
|
); |
18 |
|
|
|
19 |
|
|
|
20 |
|
|
use Data::Dumper; |
21 |
|
|
|
22 |
|
|
# we need OLE to access Outlook's Contacts via MAPI |
23 |
|
|
#use Win32::OLE::Strict; |
24 |
|
|
use Win32::OLE; |
25 |
|
|
use Win32::OLE::NLS qw(:LOCALE :DATE); |
26 |
|
|
|
27 |
|
|
use Data::Storage::Handler::File qw( s2f ); |
28 |
|
|
|
29 |
|
|
|
30 |
|
|
# get logger instance |
31 |
|
|
my $logger = Log::Dispatch::Config->instance; |
32 |
|
|
|
33 |
|
|
my $logfile_errors = '../log/mapi_errors.log'; |
34 |
|
|
|
35 |
|
|
# debugging? |
36 |
|
|
my $DEBUGLEVEL; |
37 |
|
|
my $DEBUG; |
38 |
|
|
|
39 |
|
|
|
40 |
|
|
# main vars |
41 |
|
|
my $map; |
42 |
|
|
my $map_ldap; |
43 |
|
|
|
44 |
|
|
#my $self->{_COREHANDLE}; |
45 |
|
|
my $bool_mailerAlreadyRunning; |
46 |
|
|
|
47 |
|
|
sub debugLevel { |
48 |
|
|
my $level_compare = shift; |
49 |
|
|
return 1 if ($DEBUGLEVEL > $level_compare); |
50 |
|
|
} |
51 |
|
|
|
52 |
|
|
|
53 |
|
|
|
54 |
|
|
sub getMetaInfo { |
55 |
|
|
my $self = shift; |
56 |
|
|
$logger->debug( __PACKAGE__ . "->getMetaInfo()" ); |
57 |
|
|
return { |
58 |
|
|
'disconnectMethod' => 'disconnect', |
59 |
|
|
}; |
60 |
|
|
} |
61 |
|
|
|
62 |
|
|
sub _init { |
63 |
|
|
my $self = shift; |
64 |
|
|
$self->load("Constants"); |
65 |
|
|
$self->load("Extensions"); |
66 |
|
|
#print Dumper($self); |
67 |
|
|
#$DEBUGLEVEL = $self->{config}->get("debug_level"); |
68 |
|
|
#$DEBUG = ($self->{config}->get("debug_level") > 0); |
69 |
|
|
} |
70 |
|
|
|
71 |
|
|
sub connect { |
72 |
|
|
|
73 |
|
|
my $self = shift; |
74 |
|
|
|
75 |
|
|
#print Dumper($self); |
76 |
|
|
|
77 |
|
|
$logger->info( __PACKAGE__ . ": creating mailer-object"); |
78 |
|
|
$self->{_COREHANDLE} = Win32::OLE->new('Outlook.Application') or die "oops - could not instantiate Outlook.Application"; |
79 |
|
|
|
80 |
|
|
#$self->{_COREHANDLE}->Uninitialize(); |
81 |
|
|
#sleep 2; |
82 |
|
|
|
83 |
|
|
#$self->{_COREHANDLE}->Initialize(); |
84 |
|
|
|
85 |
|
|
$bool_mailerAlreadyRunning = $self->mailerCheckRunning(); |
86 |
|
|
|
87 |
|
|
if ($bool_mailerAlreadyRunning) { |
88 |
|
|
$logger->info( __PACKAGE__ . ": *not* logging on, using running mailer"); |
89 |
|
|
} else { |
90 |
|
|
if ($self->{locator}->{showProfileChooser}) { |
91 |
|
|
$logger->info( __PACKAGE__ . ": logging in (using Profile-Chooser), this may take some seconds!"); |
92 |
|
|
$self->{_COREHANDLE}->Session->Logon ('', '', 1); |
93 |
|
|
} else { |
94 |
|
|
$logger->info( __PACKAGE__ . ": logging in (auto-selecting profile " . $self->{locator}->{ProfileName} . "), this may take some seconds!"); |
95 |
|
|
$self->{_COREHANDLE}->Session->Logon($self->{locator}->{ProfileName}, $self->{locator}->{ProfilePass}, 0); |
96 |
|
|
} |
97 |
|
|
} |
98 |
|
|
|
99 |
|
|
$self->{locator}->{status}->{connected} = 1; |
100 |
|
|
|
101 |
|
|
return 1; |
102 |
|
|
|
103 |
|
|
} |
104 |
|
|
|
105 |
|
|
sub _getConnectionInfo { |
106 |
|
|
my $self = shift; |
107 |
|
|
my $dsn = shift; |
108 |
|
|
$dsn =~ m/host=(.+?);binddn=(.+?);pass=(.+?)$/; |
109 |
|
|
my $args = { |
110 |
|
|
host => $1, |
111 |
|
|
binddn => $2, |
112 |
|
|
pass => $3, |
113 |
|
|
}; |
114 |
|
|
$args->{binddn} =~ s/'//g if $args->{binddn}; |
115 |
|
|
return $args; |
116 |
|
|
} |
117 |
|
|
|
118 |
|
|
sub existsChildNode { |
119 |
|
|
my $self = shift; |
120 |
|
|
my $nodeName = shift; |
121 |
|
|
|
122 |
|
|
$logger->debug( __PACKAGE__ . "->existsChildNode( nodeName='$nodeName' )" ); |
123 |
|
|
|
124 |
|
|
if (my $folder = $self->getContactFolder($nodeName)) { |
125 |
|
|
#print "name: ", $folder->Name, "\n"; |
126 |
|
|
return 1; |
127 |
|
|
} else { |
128 |
|
|
$logger->debug( __PACKAGE__ . "->existsChildNode: child-node doesn't exist!" ); |
129 |
|
|
return; |
130 |
|
|
} |
131 |
|
|
|
132 |
|
|
return 1; |
133 |
|
|
|
134 |
|
|
} |
135 |
|
|
|
136 |
|
|
sub disconnect { |
137 |
|
|
my $self = shift; |
138 |
|
|
|
139 |
|
|
$logger->info( __PACKAGE__ . ": logging off"); |
140 |
|
|
$self->{_COREHANDLE}->Session->Logoff; |
141 |
|
|
|
142 |
|
|
if ($bool_mailerAlreadyRunning || $self->{config}->get("mapi_neverCloseOutlook")) { |
143 |
|
|
$logger->info( __PACKAGE__ . ": *not* quitting running mailer!"); |
144 |
|
|
} else { |
145 |
|
|
$logger->info( __PACKAGE__ . ": closing active mail-explorer"); |
146 |
|
|
$self->{_COREHANDLE}->ActiveExplorer->Close; |
147 |
|
|
$logger->info( __PACKAGE__ . ": quitting mailer"); |
148 |
|
|
$self->{_COREHANDLE}->Quit; |
149 |
|
|
} |
150 |
|
|
|
151 |
|
|
#$self->{_COREHANDLE}->Uninitialize(); |
152 |
|
|
|
153 |
|
|
$logger->info( __PACKAGE__ . ": destroying mailer-object"); |
154 |
|
|
#undef $self->{_COREHANDLE}; |
155 |
|
|
|
156 |
|
|
} |
157 |
|
|
|
158 |
|
|
sub _ldapError { |
159 |
|
|
my $message = shift; |
160 |
|
|
#print Dumper($message); |
161 |
|
|
my $textMessage = "LDAP-ERROR: " . $message->error . " - code: " . $message->code; |
162 |
|
|
$textMessage .= " - dn: " . $message->{matchedDN} if $message->{matchedDN}; |
163 |
|
|
#print "msg: '$textMessage'", "\n"; |
164 |
|
|
#a2f($logfile_errors, $textMessage) if !$TRACELEVEL; |
165 |
|
|
$logger->error($textMessage); |
166 |
|
|
return $message; |
167 |
|
|
} |
168 |
|
|
|
169 |
|
|
sub getCOREHANDLE { |
170 |
|
|
my $self = shift; |
171 |
|
|
return $self->{_COREHANDLE}; |
172 |
|
|
} |
173 |
|
|
|
174 |
|
|
sub createChildNode { |
175 |
|
|
my $self = shift; |
176 |
|
|
my $nodeName = shift; |
177 |
|
|
print "createChildNode: $nodeName", "\n"; |
178 |
|
|
my $nodeDn = Data::Identifier::Dn->new(base => $self->{locator}->{basedn}, type => 'ou', name => $nodeName); |
179 |
|
|
return $self->createDn($nodeDn); |
180 |
|
|
} |
181 |
|
|
|
182 |
|
|
sub getListFiltered { |
183 |
|
|
my $self = shift; |
184 |
|
|
my $nodename = shift; |
185 |
|
|
return $self->getListUnfiltered($nodename); |
186 |
|
|
} |
187 |
|
|
|
188 |
|
|
|
189 |
|
|
my @list; |
190 |
|
|
sub cb_recieveContact { |
191 |
|
|
my $contact = shift; |
192 |
|
|
#print Dumper($contact); |
193 |
|
|
push @list, $contact; |
194 |
|
|
} |
195 |
|
|
|
196 |
|
|
sub getListUnfiltered { |
197 |
|
|
my $self = shift; |
198 |
|
|
my $nodeName = shift; |
199 |
|
|
@list = (); |
200 |
|
|
$logger->debug( __PACKAGE__ . "->getListUnfiltered( nodeName => '" . $nodeName . "' )" ); |
201 |
|
|
|
202 |
|
|
my $folder = $self->getContactFolder($nodeName); |
203 |
|
|
$self->readMapiFolder($folder, \&cb_recieveContact); |
204 |
|
|
|
205 |
|
|
#print Dumper(\@list); |
206 |
|
|
|
207 |
|
|
return \@list; |
208 |
|
|
|
209 |
|
|
=pod |
210 |
|
|
# get list of rows from rdbms by table name |
211 |
|
|
my $result = $self->sendCommand("SELECT * FROM $nodename"); |
212 |
|
|
while ( my $row = $result->getNextEntry() ) { |
213 |
|
|
push @list, $row; |
214 |
|
|
} |
215 |
|
|
return \@list; |
216 |
|
|
=cut |
217 |
|
|
|
218 |
|
|
} |
219 |
|
|
|
220 |
|
|
1; |