emailservices/emailclientapi/inc/emailclientapiimpl.h
author hgs
Mon, 23 Aug 2010 23:32:31 +0300
changeset 62 a8c646b56683
parent 47 f83bd4ae1fe3
child 76 38bf5461e270
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
47
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: Definition of Email API main interface.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef EMAILCLIENTAPIIMPL_H
hgs
parents:
diff changeset
    19
#define EMAILCLIENTAPIIMPL_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <implementationinformation.h> 
hgs
parents:
diff changeset
    23
#include "emailapiutils.h"
62
hgs
parents: 47
diff changeset
    24
#include "CFSMailCommon.h"
hgs
parents: 47
diff changeset
    25
#include "MFSMailEventObserver.h"    
47
hgs
parents:
diff changeset
    26
#include <memailclientapi.h>
hgs
parents:
diff changeset
    27
#include "emailclientpluginmanager.h"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
using namespace EmailInterface;
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
class CFSMailBox;
hgs
parents:
diff changeset
    33
class MEmailEventObserver;
hgs
parents:
diff changeset
    34
class CVwsSessionWrapper;
hgs
parents:
diff changeset
    35
class CFSMailPlugin;
hgs
parents:
diff changeset
    36
class TFSMailMsgId;
hgs
parents:
diff changeset
    37
class CEmailMailboxCache;
hgs
parents:
diff changeset
    38
class CFSMailClient;
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
/**
hgs
parents:
diff changeset
    41
*  "Framework" class including plugin management
hgs
parents:
diff changeset
    42
* @since S60 v5.2
hgs
parents:
diff changeset
    43
*/
hgs
parents:
diff changeset
    44
NONSHARABLE_CLASS( CEmailClientApi ) : public CBase, public MEmailClientApi
hgs
parents:
diff changeset
    45
{
hgs
parents:
diff changeset
    46
public:
hgs
parents:
diff changeset
    47
    /**
hgs
parents:
diff changeset
    48
    * Constructor
hgs
parents:
diff changeset
    49
    * @return
hgs
parents:
diff changeset
    50
    */
hgs
parents:
diff changeset
    51
    static CEmailClientApi* NewL();
hgs
parents:
diff changeset
    52
    
hgs
parents:
diff changeset
    53
    /**
hgs
parents:
diff changeset
    54
     *
hgs
parents:
diff changeset
    55
     */
hgs
parents:
diff changeset
    56
     CEmailClientApi();       
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
public: // from MEmailInterface
hgs
parents:
diff changeset
    59
    TEmailTypeId InterfaceId() const;
hgs
parents:
diff changeset
    60
    
hgs
parents:
diff changeset
    61
    void Release();
hgs
parents:
diff changeset
    62
    
hgs
parents:
diff changeset
    63
public: // from MEmailClientApi
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
    /** @see MEmailClientApi */   
hgs
parents:
diff changeset
    66
    MEmailMailbox* MailboxL( const TMailboxId& aId );
hgs
parents:
diff changeset
    67
   
hgs
parents:
diff changeset
    68
    /** @see MEmailClientApi */   
hgs
parents:
diff changeset
    69
    MEmailMailbox* MailboxL( const TPtrC& aAddress );
hgs
parents:
diff changeset
    70
           
hgs
parents:
diff changeset
    71
    /**
hgs
parents:
diff changeset
    72
    * Gets all mailboxes in pointer array. It is recommended to free other
hgs
parents:
diff changeset
    73
    * mailboxes besides needed one to optimise memory usage.
hgs
parents:
diff changeset
    74
    */    
hgs
parents:
diff changeset
    75
    TInt GetMailboxesL( RMailboxPtrArray& aMailboxes );
hgs
parents:
diff changeset
    76
    
hgs
parents:
diff changeset
    77
    /**
hgs
parents:
diff changeset
    78
    */
hgs
parents:
diff changeset
    79
    void LaunchEmailL( const TLaunchPolicy aPolicy );
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
public: // new methods
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
    /**
hgs
parents:
diff changeset
    84
     * Gets array of mailbox ids
hgs
parents:
diff changeset
    85
     * @param aMailboxes mailbox ids from all plugins
hgs
parents:
diff changeset
    86
     * @return number of mailboxes returned in aMailboxes
hgs
parents:
diff changeset
    87
     */
hgs
parents:
diff changeset
    88
    TInt GetMailboxIdsL( REmailMailboxIdArray& aMailboxes );
hgs
parents:
diff changeset
    89
        
hgs
parents:
diff changeset
    90
private:
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
    /**
hgs
parents:
diff changeset
    93
     * Constructor
hgs
parents:
diff changeset
    94
     */
hgs
parents:
diff changeset
    95
    void ConstructL();
hgs
parents:
diff changeset
    96
    
hgs
parents:
diff changeset
    97
     /**
hgs
parents:
diff changeset
    98
     * Destructor
hgs
parents:
diff changeset
    99
     */
hgs
parents:
diff changeset
   100
    ~CEmailClientApi();
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
    /**
hgs
parents:
diff changeset
   103
     * Push ECom implementation info to cleanup operation to cleanup stack
hgs
parents:
diff changeset
   104
     */
hgs
parents:
diff changeset
   105
    void CleanupImplInfoPushL( RPointerArray<CImplementationInformation>& aArray );
hgs
parents:
diff changeset
   106
    
hgs
parents:
diff changeset
   107
    /**
hgs
parents:
diff changeset
   108
     * Cleanup operation for ECom implementation info
hgs
parents:
diff changeset
   109
     */
hgs
parents:
diff changeset
   110
    static void CleanupImplInfo( TAny* aAny );
hgs
parents:
diff changeset
   111
   
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
    // Group of methods for book keeping of loaded protocol plugins by this object.
hgs
parents:
diff changeset
   114
    // In certain situations it is preferable to have a plugin in memory
hgs
parents:
diff changeset
   115
    // instead of loading/unloading frequently.
hgs
parents:
diff changeset
   116
    
hgs
parents:
diff changeset
   117
    /** Increases plugin reference count if CEmailClientApi already doesn't
hgs
parents:
diff changeset
   118
     *  have active instance. When plugin is needed internally, this method
hgs
parents:
diff changeset
   119
     * should be accessor to a plugin. Counterpart is ReleasePlugin() when
hgs
parents:
diff changeset
   120
     * CEmailClientApi doesn't itself need plugin any more.
hgs
parents:
diff changeset
   121
     */
hgs
parents:
diff changeset
   122
    CFSMailPlugin* UsePlugin( CPluginData& aPluginData );
hgs
parents:
diff changeset
   123
    
hgs
parents:
diff changeset
   124
    /**
hgs
parents:
diff changeset
   125
    * For finding plugin data
hgs
parents:
diff changeset
   126
    */
hgs
parents:
diff changeset
   127
    TInt IndexOfLoadedPluginData( const TPluginData& aPluginData ) const;
hgs
parents:
diff changeset
   128
    
hgs
parents:
diff changeset
   129
    /**
hgs
parents:
diff changeset
   130
    * Used in comparing plugin data in array (part of find algorithm)
hgs
parents:
diff changeset
   131
    */    
hgs
parents:
diff changeset
   132
    static TBool PluginDataEquals( const TPluginData& a1, const TPluginData& a2 );
hgs
parents:
diff changeset
   133
    
hgs
parents:
diff changeset
   134
    /**
hgs
parents:
diff changeset
   135
    * This object doesn't need related protocol plugin
hgs
parents:
diff changeset
   136
    */
hgs
parents:
diff changeset
   137
    void ReleasePlugin( CPluginData& aPluginData );
hgs
parents:
diff changeset
   138
    
hgs
parents:
diff changeset
   139
    /**
hgs
parents:
diff changeset
   140
    * This object doesn't need any protocol plugin
hgs
parents:
diff changeset
   141
    */
hgs
parents:
diff changeset
   142
    void ReleaseAllPlugins();
hgs
parents:
diff changeset
   143
    
hgs
parents:
diff changeset
   144
    /**
hgs
parents:
diff changeset
   145
    * Return mailbox cache, creates it when called first time
hgs
parents:
diff changeset
   146
    */
hgs
parents:
diff changeset
   147
    CEmailMailboxCache& MailboxInfoCacheL();
hgs
parents:
diff changeset
   148
    
hgs
parents:
diff changeset
   149
    /**
hgs
parents:
diff changeset
   150
    * Caches mailbox ids and their mapping to related plugin data for quick
hgs
parents:
diff changeset
   151
    * lookup. When a mailbox with specific id is next time asked, related
hgs
parents:
diff changeset
   152
    * protocol plugin is already known.
hgs
parents:
diff changeset
   153
    */
hgs
parents:
diff changeset
   154
    void UpdateMailboxInfoCacheL();
hgs
parents:
diff changeset
   155
hgs
parents:
diff changeset
   156
    /**
hgs
parents:
diff changeset
   157
    * Internal, used from UpdateMailboxInfoCacheL
hgs
parents:
diff changeset
   158
    */    
hgs
parents:
diff changeset
   159
    TBool CachePluginMailboxesL( 
hgs
parents:
diff changeset
   160
        CPluginData& aPluginData, 
hgs
parents:
diff changeset
   161
        CFSMailPlugin& aPlugin );
hgs
parents:
diff changeset
   162
    
hgs
parents:
diff changeset
   163
private:    
hgs
parents:
diff changeset
   164
    typedef RPointerArray<CPluginData> RPluginDataArray;
hgs
parents:
diff changeset
   165
    
hgs
parents:
diff changeset
   166
    /**
hgs
parents:
diff changeset
   167
    * Iterator for CPluginData elements in an array
hgs
parents:
diff changeset
   168
    */
hgs
parents:
diff changeset
   169
    class TPluginIterator
hgs
parents:
diff changeset
   170
    {
hgs
parents:
diff changeset
   171
    public:
hgs
parents:
diff changeset
   172
        // constructor
hgs
parents:
diff changeset
   173
        inline TPluginIterator( RPluginDataArray& aArray ) : 
hgs
parents:
diff changeset
   174
            iArray( aArray ), iIndex( 0 ) {}
hgs
parents:
diff changeset
   175
        
hgs
parents:
diff changeset
   176
        /**
hgs
parents:
diff changeset
   177
        * return next element
hgs
parents:
diff changeset
   178
        */
hgs
parents:
diff changeset
   179
        CPluginData* Next();
hgs
parents:
diff changeset
   180
    private:
hgs
parents:
diff changeset
   181
        // iterator array
hgs
parents:
diff changeset
   182
        RPluginDataArray& iArray;
hgs
parents:
diff changeset
   183
        // current iterator index
hgs
parents:
diff changeset
   184
        TInt iIndex;
hgs
parents:
diff changeset
   185
    };
hgs
parents:
diff changeset
   186
    
hgs
parents:
diff changeset
   187
private:
hgs
parents:
diff changeset
   188
    // plugin data array for all protocol plugins
hgs
parents:
diff changeset
   189
    RPluginDataArray    iPluginDataArray;
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
    // singleton instance counter    
hgs
parents:
diff changeset
   192
    TInt iInstanceCounter;
hgs
parents:
diff changeset
   193
    
hgs
parents:
diff changeset
   194
    // book keeping of loaded plugins
hgs
parents:
diff changeset
   195
    RArray<TPluginData> iLoadedPluginsArray;
hgs
parents:
diff changeset
   196
       
hgs
parents:
diff changeset
   197
    // Mailbox ids are cached when first time listed. Related plugin uid
hgs
parents:
diff changeset
   198
    // is include in the cache.
hgs
parents:
diff changeset
   199
    CEmailMailboxCache* iMailboxCache;
hgs
parents:
diff changeset
   200
hgs
parents:
diff changeset
   201
    CFSMailClient* iMailClient;
hgs
parents:
diff changeset
   202
    
hgs
parents:
diff changeset
   203
};
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
/**
hgs
parents:
diff changeset
   206
* Email application launcher. 
hgs
parents:
diff changeset
   207
*/
hgs
parents:
diff changeset
   208
NONSHARABLE_CLASS( CEmailLauncher ) : public CBase
hgs
parents:
diff changeset
   209
{
hgs
parents:
diff changeset
   210
public:
hgs
parents:
diff changeset
   211
    static CEmailLauncher* NewL();
hgs
parents:
diff changeset
   212
    
hgs
parents:
diff changeset
   213
    ~CEmailLauncher();
hgs
parents:
diff changeset
   214
                                    
hgs
parents:
diff changeset
   215
    /**
hgs
parents:
diff changeset
   216
    *
hgs
parents:
diff changeset
   217
    */
hgs
parents:
diff changeset
   218
     void LaunchL( const TMailboxId& aMailboxId );
hgs
parents:
diff changeset
   219
private:
hgs
parents:
diff changeset
   220
    
hgs
parents:
diff changeset
   221
    CEmailLauncher();
hgs
parents:
diff changeset
   222
    
hgs
parents:
diff changeset
   223
    void ConstructL();
hgs
parents:
diff changeset
   224
    
hgs
parents:
diff changeset
   225
    // Owned window server session.
hgs
parents:
diff changeset
   226
    CVwsSessionWrapper* iViewSrvSession;
hgs
parents:
diff changeset
   227
};
hgs
parents:
diff changeset
   228
hgs
parents:
diff changeset
   229
hgs
parents:
diff changeset
   230
#endif // EMAILCLIENTAPIIMPL_H
hgs
parents:
diff changeset
   231
hgs
parents:
diff changeset
   232
// End of file