/[cvs]/nfo/perl/scripts/outlook2ldap/libs/Torus.pod
ViewVC logotype

Annotation of /nfo/perl/scripts/outlook2ldap/libs/Torus.pod

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (hide annotations)
Sun Jan 19 07:45:05 2003 UTC (21 years, 11 months ago) by joko
Branch: MAIN
+ initial check-in

1 joko 1.1 =pod
2    
3     =head1 NAME
4    
5     Torus
6    
7    
8     =head1 DESCRIPTION
9    
10     Torus is a module to ease migration from Outlook.
11    
12     Torus uses CPAN's Win32::OLE to access Microsoft's MAPI locally and
13     CPAN's Net::LDAP to connect to a remote OpenLDAP-server (slapd).
14    
15     Access to these storage-implementations is wrapped via Data::Storage.
16     Core functionality of Torus is currently provided from Data::Transfer::Sync.
17    
18     We are starting with Contacts/Adresses, will go along with Messages,
19     Calendar-Items and Journaling-Features.
20     The "rest" should be able to be modeled and implemented on top of this.
21    
22     This is more a reference implementation than anything actually useful. ;-)
23     You'll also like to take a look at:
24     - Kroupware Project: http://kroupware.kde.org
25     - Outlook Connector Project: http://otlkcon.sourceforge.net
26     - bynari InsightConnector: http://bynari.net/index.php?id=7
27    
28    
29     =head1 NEWS
30    
31     =head4 2003-01-18 - initial check-in
32    
33    
34     =head1 REQUIREMENTS
35    
36     Win32::OLE
37     Net::LDAP
38     Data::Storage
39     Data::Transfer::Sync
40     ... and all their dependencies
41    
42    
43     =head1 AUTHORS / COPYRIGHT
44    
45     The Data::Storage module is Copyright (c) 2002 Andreas Motl.
46     All rights reserved.
47    
48     You may distribute it under the terms of either the GNU General Public
49     License or the Artistic License, as specified in the Perl README file.
50    
51    
52     =head1 CONTRIBUTORS
53    
54     Jan Hoffmann <jan@romain-volk.com>
55     Sebastian Utz <s.utz@tunemedia.de>
56    
57    
58     =head1 SUPPORT / WARRANTY
59    
60     Data::Storage is free software. IT COMES WITHOUT WARRANTY OF ANY KIND.
61    
62    
63    
64     =head1 BUGS
65    
66    
67    
68     =head1 TODO
69    
70     - outlook2ldap - essential modules:
71     - Net::LDAP
72     - Convert::ASN1 / BER1
73     - Unicode::String
74     - MIME::Base64
75     o use setup.pm with autoinstall, use ExtUtils::MakeMaker and/or h2xs
76     x extend logging/debugging-output (logfiles below log/)
77     o enhance mapping through expressions
78     o provide multiple use of same fields
79     o provide mechanism to concatenate fields
80     --> see etc/_future!
81     o make integrated setup
82     o provide gui(s)
83     o development (create mappings and stuff (testing, ...))
84     o productive use (control sync-processing at a central console)
85     o little hotsync-button (iconbar bottom-right) which provides some actions and some configuration-settings (put ACLs on these settings?)
86     o move libs/Torus to nfo-modules, exclude various metadata needed to actually sync with ldap and mappings (csv-files)
87     o provide example to sync with mysql/Tangram/mbox/...
88     o integrate genSchema.pl
89     o regeln:
90     o 3.spalte in outlook_ole_fields.csv: für "genSchema.pl"
91     o wenn 2.spalte und/oder 3. leer, dann wird kein mapping gemacht (genSchema sowieso nicht)
92     --> see etc/_future!
93     +- beliebige outlook-ordner zu ldap-ou's mappen
94     + fest deklarierte (level 1)
95     o tief referenzierte (level X) (!!!) (backup->Addressen->XYZ - Addressen)
96     o daten "rückwärts" übertragen!
97     + bugfix: utf8
98     o mapping aufbohren (csv -> xml) - integrate "schema"-property _per-field_!!!
99     o have the engine use this
100     o maybe provide cross-checks
101     --> see etc/_future!
102     o clean-up debugging (levels)
103     + debugging-level does not work when error occours in Net::LDAP::Entry while adding...
104     + display MAPI-object as hash
105     o transfer statistics
106     o zugriff auf outlook (2002) ohne rückfrage gewähren?
107     o v.a. wichtig, wenn integrierter zugriff (z.b. durch outlook-plugin) stattfindet
108     + verwenden _aller_ attribute, die mit einem address-eintrag assoziiert sein können?
109     + mileage (reisekilometer) kommt!
110     + bis dato unbekannte mapi-felder sollten nun auch verwendet werden können
111     o declare folder-mapping inside xml-file
112     o check-before-delete doesn't seem to work (again!)
113     o make basedn configurable
114     o introduce host-to-basedn-mapping
115     o provide additional fallback basedn
116     o maybe additional permissions for folder-autocreation
117     o rework regexes in Torus::Driver::ldap
118     o spaces in ou's?
119     o utf8-encoding for dn's in ou's
120     o also in other property-names (besides the attributes)?!
121     o ä, ö, ü
122     o Insight:
123     o cclient.dll
124     o InsightConnector.dll
125     o folder-mapping
126     o leerzeichen (non-word-chars) do not work inside foldernames
127     o regex fails:
128     o introduce some "highlevel-splitting" of ldap-addresses
129     o fix problems occoured 2003-01-06/07 @barschwaechter: rules, access to mapi, etc. (see email)
130     + syncOutlookContacts.pl --mapidump
131     + provide better workflow for development phase(s)
132     + configurable debugging
133     + configurable tracing
134     o do a _true_ sync! (no delete/add)
135     o handle folder-mapping/-creation completely _before_ continuing with single entries
136     o create non-existant and stuff....
137     o timestamp log-entries
138     o add fieldname-context to ldap_errors.log
139     o regeln für cn/dn - build
140     o wenn "sn" gesetzt, dann nimm "sn" als "cn"
141     o wenn "givenname" gesetzt, dann füge zu "cn" hinzu (bisheriger "build"-Vorgang)
142     o wenn "sn" leer, dann nimm stattdessen "FileAs" als "cn" und ab [Debug Level=1]info
143     o wenn "FileAs" leer, dann nimm stattdessen "FirstName" und ab [Debug Level=1]info
144     o wenn "FirstName" leer, dann nimm stattdessen "CompanyName" und ab [Debug Level=1]info
145     else ab [Debug Level=1] Warn:
146     "Couldn't build DN/CN cause neighter SN/FileAs/FirstName/CompanyName does exist." (Should not happen).
147     o collision checks!!!
148     o convert date-fields
149     o detect must-not-have characters in dn:
150     + replace "+" through "&"
151     o replace "," through "" [Kill]
152     o replace "ô" through "" [to UTF8]
153     o enhance mechanisms to talk to OLE:
154     o use "->EnumAllObjects"
155     o use "->FreeUnusedLibraries"
156     o use "->LastError"
157     o encode "dn" with utf8
158     o "member" is empty!!!
159     o free resources while processing
160     o Outlook (OLE)
161     o Perl (Variables, Objects)
162     o LDAP-Server (Handle)
163    
164     + integration with Data::Storage and Data::Transfer
165     + thrown away "L:" and "R:" o declarations for/in Data::Transfer::Sync
166     o split 'syncOutlookContacts.ini' into 'torus.ini' and 'outlook2ldap.ini'
167     o 'syncOutlookContacts.pl' reads 'outlook2ldap.ini' and runs 'feed.pl'
168     + Data::Transfer::Sync now utilizes DesignPattern::Object and DesignPattern::Bridge
169    
170     o for Horde:
171     o helper: some kinda "genSchema.pl"
172     o app: LDAP-Browser
173    
174    
175     =head1 IDEAS
176    
177     o acl based permissions (use Data::ACL?)
178     o combine Torus::Xyz with Device::Xyz somehow?
179     o assure published stuff contains no client-specific informations (HMI, ...)
180     o CPAN's AppConfig is still needed for now (could this be changed? e.g. using App::Config?)
181     o if not, just include it below "libs" or install "nmake" (through integrated setup) before configuring CPAN
182     (if you already have, do "perl -MCPAN -eshell" and "o conf init" to redo configuration)
183     o rework folder-mapping to use xml
184     o rework field-mapping to use xml (Data::Transfer::Sync!)
185     o rework declaration of while-transfer-rules and after-transfer-patches to xml
186     o example of a "while-transfer-rule"
187     o build "dn" from "cn/sn"
188     o must have "sn"
189     o if no "sn" given, just use "Vorname"
190     o don't allow some special characters inside "dn": '+' seems to get translated to '&' at somewhere in code
191     o example of a "after-transfer-patch-rule"
192     o copy contents of field "x" to field "y" to nivelate(?) access from ldap-query-engines we don't have access to! (the source!)
193     (e.g. query-/search-engines in commercial products like "MS Outlook 2000|2002|Express",
194     which also don't have _any_ mechanism to parametrize them)
195     o write papers about networking (computers _and_ small/embedded/electronic devices (atmel, c-control))
196     o janosch: how to control arbitrary devices via personal computers _and_ standalone circuits in parallel!
197     (using Device::SerialPort and Conrad C-Control together)
198     o implement infrastructure(s)
199     o actually handle folders (check, autocreation) completely _before_ starting to sync/process items/entries!
200     o provide easy-to-access shell-interface to LDAP (e.g. via Xyz::Xyz or (maybe later) "oedit.pl")
201     o this removes the need for the currently used Java-based Ldap-Client (which will stay more comfortable - of course)
202     o navigate via "cd" through containers, show items/entries via (e.g.) "dump"(?) and stuff...
203     ... the interactive feeling/behaviour is similar to navigating in a filesystem via a commandline-interface (CLI)
204     o sum up "must-have" features of known synchronization-tools for (e.g.) ...
205     o s25@once
206     o siemens custom sync (S45Sync.exe?)
207     o Nokia Communicator
208     o SyncML (it's not a device from a manufacturer, it's actually a XML-standard) -> sync4j@sourceforge
209     o use news (the nntp-protocol) for journalling-functionality
210     o have mapping stored inside ldap as well
211    
212    
213     =cut

MailToCvsAdmin">MailToCvsAdmin
ViewVC Help
Powered by ViewVC 1.1.26 RSS 2.0 feed