emailservices/emailclientapi/inc/emailmessagesearch.h
author hgs
Thu, 24 Jun 2010 14:32:18 +0300
changeset 47 f83bd4ae1fe3
child 62 a8c646b56683
permissions -rw-r--r--
201025
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 message search API.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef EMAILMESSAGESEARCHASYNCIMPL_H_
hgs
parents:
diff changeset
    19
#define EMAILMESSAGESEARCHASYNCIMPL_H_
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <memailmessage.h>
hgs
parents:
diff changeset
    22
#include <memailmessagesearch.h>
hgs
parents:
diff changeset
    23
#include <emailsorting.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
#include "cfsmailclient.h"
hgs
parents:
diff changeset
    26
#include "mfsmailboxsearchobserver.h"
hgs
parents:
diff changeset
    27
#include "emailapiutils.h"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
using namespace EmailInterface;
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
NONSHARABLE_CLASS( CEmailMessageSearchAsync) : 
hgs
parents:
diff changeset
    33
    public CBase, 
hgs
parents:
diff changeset
    34
    public MEmailMessageSearchAsync, 
hgs
parents:
diff changeset
    35
    public MFSMailBoxSearchObserver
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
{
hgs
parents:
diff changeset
    38
public:
hgs
parents:
diff changeset
    39
    /**
hgs
parents:
diff changeset
    40
    * Constructor
hgs
parents:
diff changeset
    41
    * @return
hgs
parents:
diff changeset
    42
    */
hgs
parents:
diff changeset
    43
    static CEmailMessageSearchAsync* NewL(
hgs
parents:
diff changeset
    44
        CPluginData& aPluginData,
hgs
parents:
diff changeset
    45
        const TMailboxId& aMailboxId );
hgs
parents:
diff changeset
    46
    
hgs
parents:
diff changeset
    47
    /**
hgs
parents:
diff changeset
    48
     * Destructor
hgs
parents:
diff changeset
    49
     */
hgs
parents:
diff changeset
    50
    ~CEmailMessageSearchAsync();
hgs
parents:
diff changeset
    51
    
hgs
parents:
diff changeset
    52
public: // from MEmailInterface
hgs
parents:
diff changeset
    53
    TEmailTypeId InterfaceId() const;
hgs
parents:
diff changeset
    54
    
hgs
parents:
diff changeset
    55
    void Release();
hgs
parents:
diff changeset
    56
    
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
public: // from MEmailMessageSearchAsync
hgs
parents:
diff changeset
    59
    /**
hgs
parents:
diff changeset
    60
    * Sets sort order for search results.
hgs
parents:
diff changeset
    61
    * Leaves KErrNotReady if search is ongoing.
hgs
parents:
diff changeset
    62
    */
hgs
parents:
diff changeset
    63
    void SetSortCriteriaL( const TEmailSortCriteria& aCriteria );
hgs
parents:
diff changeset
    64
    
hgs
parents:
diff changeset
    65
    /**
hgs
parents:
diff changeset
    66
    * Adds a search key. Leaves KErrNotReady if search is ongoing.
hgs
parents:
diff changeset
    67
    */
hgs
parents:
diff changeset
    68
    void AddSearchKeyL( const TDesC& aSearchKey );
hgs
parents:
diff changeset
    69
                                                                  
hgs
parents:
diff changeset
    70
    /**
hgs
parents:
diff changeset
    71
    * Enables/disables search from remote email server.
hgs
parents:
diff changeset
    72
    * Leaves KErrNotReady if search is ongoing.
hgs
parents:
diff changeset
    73
    */
hgs
parents:
diff changeset
    74
    void SetRemoteSearchL( TBool aRemote );                                                               
hgs
parents:
diff changeset
    75
    
hgs
parents:
diff changeset
    76
    /**
hgs
parents:
diff changeset
    77
    * Indicates whether remote search is enabled.
hgs
parents:
diff changeset
    78
    */
hgs
parents:
diff changeset
    79
    TBool IsRemoteSearch() const;
hgs
parents:
diff changeset
    80
    
hgs
parents:
diff changeset
    81
    /**
hgs
parents:
diff changeset
    82
     * Starts search, all methods affecting search attribures leave
hgs
parents:
diff changeset
    83
     * KErrNotReady while search is ongoing.
hgs
parents:
diff changeset
    84
     * @param aObserver called when results are available.
hgs
parents:
diff changeset
    85
     */     
hgs
parents:
diff changeset
    86
    void StartSearchL( MEmailSearchObserver& aObserver );
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
    /**
hgs
parents:
diff changeset
    89
     * Cancels search.
hgs
parents:
diff changeset
    90
     */
hgs
parents:
diff changeset
    91
    void Cancel();
hgs
parents:
diff changeset
    92
                                             
hgs
parents:
diff changeset
    93
    /** returns search status 
hgs
parents:
diff changeset
    94
      * @return search status:
hgs
parents:
diff changeset
    95
      *     < 0 : Search has failed
hgs
parents:
diff changeset
    96
      *     KRequestPending : search is ongoing. note that status may be
hgs
parents:
diff changeset
    97
      *         KRequestPending after HandleResultL callback because results 
hgs
parents:
diff changeset
    98
      *         may be given in chunks of results. Size of chunk depends on
hgs
parents:
diff changeset
    99
      *         implementation and may vary.
hgs
parents:
diff changeset
   100
      *     KErrNone : initial state, or search has finished
hgs
parents:
diff changeset
   101
      */
hgs
parents:
diff changeset
   102
    TInt Status() const;
hgs
parents:
diff changeset
   103
    
hgs
parents:
diff changeset
   104
    /**
hgs
parents:
diff changeset
   105
     * Resets all search attribures. Cancels search if ongoing. 
hgs
parents:
diff changeset
   106
     */
hgs
parents:
diff changeset
   107
    void Reset();
hgs
parents:
diff changeset
   108
    
hgs
parents:
diff changeset
   109
public:  // From MFSMailBoxSearchObserver
hgs
parents:
diff changeset
   110
    /** 
hgs
parents:
diff changeset
   111
     * Notifies the email search API client that a match has been found
hgs
parents:
diff changeset
   112
     * 
hgs
parents:
diff changeset
   113
     * @param aMatchMessage contains a pointer to the matched message.
hgs
parents:
diff changeset
   114
     *         Ownership is transfered to the observer.
hgs
parents:
diff changeset
   115
     *
hgs
parents:
diff changeset
   116
     */
hgs
parents:
diff changeset
   117
     void MatchFoundL( CFSMailMessage* aMatchMessage );
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
    /**
hgs
parents:
diff changeset
   120
     * Notifies the email search API client that the search has completed
hgs
parents:
diff changeset
   121
     *
hgs
parents:
diff changeset
   122
     */
hgs
parents:
diff changeset
   123
     void SearchCompletedL();
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
//
hgs
parents:
diff changeset
   126
    /**
hgs
parents:
diff changeset
   127
    * Asks client if search engine should change search priority 
hgs
parents:
diff changeset
   128
  	*/
hgs
parents:
diff changeset
   129
    void ClientRequiredSearchPriority(TInt *apRequiredSearchPriority); 
hgs
parents:
diff changeset
   130
//
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
    
hgs
parents:
diff changeset
   133
private:
hgs
parents:
diff changeset
   134
    /**
hgs
parents:
diff changeset
   135
     * Constructor
hgs
parents:
diff changeset
   136
     */
hgs
parents:
diff changeset
   137
    CEmailMessageSearchAsync(
hgs
parents:
diff changeset
   138
        CPluginData& aPluginData,
hgs
parents:
diff changeset
   139
        const TMailboxId& aMailboxId );
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
    void ConstructL();
hgs
parents:
diff changeset
   142
    
hgs
parents:
diff changeset
   143
    /**
hgs
parents:
diff changeset
   144
     * Function leaves if search is going on. Otherwise it doesn't do anything.
hgs
parents:
diff changeset
   145
     */
hgs
parents:
diff changeset
   146
    inline void IsSearchGoingOnL() const; 
hgs
parents:
diff changeset
   147
hgs
parents:
diff changeset
   148
private:
hgs
parents:
diff changeset
   149
    
hgs
parents:
diff changeset
   150
    CPluginData&    iPluginData;
hgs
parents:
diff changeset
   151
    
hgs
parents:
diff changeset
   152
    CFSMailPlugin*  iPlugin;
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
    TMailboxId      iMailboxId;
hgs
parents:
diff changeset
   155
    
hgs
parents:
diff changeset
   156
    TFSMailSortCriteria iCriteria;
hgs
parents:
diff changeset
   157
        
hgs
parents:
diff changeset
   158
    RPointerArray<TDesC> iSearchStrings;    
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
    MEmailSearchObserver* iObserver;
hgs
parents:
diff changeset
   161
    
hgs
parents:
diff changeset
   162
    mutable RSemaphore iGate;
hgs
parents:
diff changeset
   163
hgs
parents:
diff changeset
   164
    TBool iRemote;
hgs
parents:
diff changeset
   165
};
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
#endif // EMAILMESSAGESEARCHASYNCIMPL_H_
hgs
parents:
diff changeset
   168
hgs
parents:
diff changeset
   169
// End of file
hgs
parents:
diff changeset
   170