email_plat/email_client_api/inc/memailmessagesearch.h
author hgs
Thu, 30 Sep 2010 11:43:07 +0300
changeset 74 6c59112cfd31
parent 47 email_plat/email_client_api/memailmessagesearch.h@f83bd4ae1fe3
permissions -rw-r--r--
201039
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: ECom interface for Email Client API
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef __MEMAILACTIONS
hgs
parents:
diff changeset
    19
#define __MEMAILACTIONS
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <e32cmn.h>
hgs
parents:
diff changeset
    22
#include <memailmessage.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
namespace EmailInterface {
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
class MMessageIterator;
hgs
parents:
diff changeset
    27
class TEmailSortCriteria;
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
/**
hgs
parents:
diff changeset
    30
* Observer interface for handling email search results.
hgs
parents:
diff changeset
    31
*/
hgs
parents:
diff changeset
    32
class MEmailSearchObserver
hgs
parents:
diff changeset
    33
{
hgs
parents:
diff changeset
    34
public:
hgs
parents:
diff changeset
    35
    /**
hgs
parents:
diff changeset
    36
     * Called when search has next message available.
hgs
parents:
diff changeset
    37
     * This callback is called several times until all results
hgs
parents:
diff changeset
    38
     * have been delivered.
hgs
parents:
diff changeset
    39
     *
hgs
parents:
diff changeset
    40
     * @param message found in search, ownership is transferred.
hgs
parents:
diff changeset
    41
     *          
hgs
parents:
diff changeset
    42
     */ 
hgs
parents:
diff changeset
    43
    virtual void HandleResultL( 
hgs
parents:
diff changeset
    44
        MEmailMessage* aMessage ) = 0;
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
    /**
hgs
parents:
diff changeset
    47
     * Notifies that the search has completed and no more results are expected.
hgs
parents:
diff changeset
    48
     */
hgs
parents:
diff changeset
    49
    virtual void SearchCompletedL() = 0;
hgs
parents:
diff changeset
    50
};
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
/**
hgs
parents:
diff changeset
    53
 * Search interface for messages. Results are provided asynchronoysly.
hgs
parents:
diff changeset
    54
 * By default all found mailboxes are included in search.
hgs
parents:
diff changeset
    55
 * @code
hgs
parents:
diff changeset
    56
   
hgs
parents:
diff changeset
    57
   MEmailMailbox* mailbox = NULL;
hgs
parents:
diff changeset
    58
   // obtain mailbox here... 
hgs
parents:
diff changeset
    59
   // ...and now get search interface
hgs
parents:
diff changeset
    60
   MEmailMessageSearchAsync* search = mailbox->MessageSearchL();
hgs
parents:
diff changeset
    61
   CleanupReleasePushL( *search );
hgs
parents:
diff changeset
    62
   TEmailSortCriteria criteria;
hgs
parents:
diff changeset
    63
   criteria.iAscending = ETrue;
hgs
parents:
diff changeset
    64
   criteria.iField = TEmailSortCriteria::EByDate;                 
hgs
parents:
diff changeset
    65
   search->SetSortCriteriaL( criteria );
hgs
parents:
diff changeset
    66
   search->StartSearchL( *this ); // this implements MEmailSearchObserver
hgs
parents:
diff changeset
    67
   search->Cancel(); // cancel search
hgs
parents:
diff changeset
    68
   CleanupStack::PopAndDestroy(); // search
hgs
parents:
diff changeset
    69
   
hgs
parents:
diff changeset
    70
   @endcode
hgs
parents:
diff changeset
    71
   
hgs
parents:
diff changeset
    72
 * @since S60 v5.0
hgs
parents:
diff changeset
    73
 */
hgs
parents:
diff changeset
    74
class MEmailMessageSearchAsync : public MEmailInterface
hgs
parents:
diff changeset
    75
{
hgs
parents:
diff changeset
    76
public:
hgs
parents:
diff changeset
    77
        
hgs
parents:
diff changeset
    78
    /**
hgs
parents:
diff changeset
    79
    * Sets sort order for search results.
hgs
parents:
diff changeset
    80
    * Leaves KErrNotReady if search is ongoing.
hgs
parents:
diff changeset
    81
    */
hgs
parents:
diff changeset
    82
    virtual void SetSortCriteriaL( const TEmailSortCriteria& aCriteria ) = 0;
hgs
parents:
diff changeset
    83
    
hgs
parents:
diff changeset
    84
    /**
hgs
parents:
diff changeset
    85
    * Adds a search key. Leaves KErrNotReady if search is ongoing.
hgs
parents:
diff changeset
    86
    */
hgs
parents:
diff changeset
    87
    virtual void AddSearchKeyL( const TDesC& aSearchKey ) = 0;
hgs
parents:
diff changeset
    88
                                                                  
hgs
parents:
diff changeset
    89
    /**
hgs
parents:
diff changeset
    90
    * Enables/disables search from remote email server.
hgs
parents:
diff changeset
    91
    * Leaves KErrNotReady if search is ongoing.
hgs
parents:
diff changeset
    92
    */
hgs
parents:
diff changeset
    93
    virtual void SetRemoteSearchL( TBool aRemote ) = 0;                                                                  
hgs
parents:
diff changeset
    94
    
hgs
parents:
diff changeset
    95
    /**
hgs
parents:
diff changeset
    96
    * Indicates whether remote search is enabled.
hgs
parents:
diff changeset
    97
    */
hgs
parents:
diff changeset
    98
    virtual TBool IsRemoteSearch() const = 0;
hgs
parents:
diff changeset
    99
    
hgs
parents:
diff changeset
   100
    /**
hgs
parents:
diff changeset
   101
     * Starts search, all methods affecting search attribures leave
hgs
parents:
diff changeset
   102
     * KErrNotReady while search is ongoing.
hgs
parents:
diff changeset
   103
     * @param aObserver called when results are available.
hgs
parents:
diff changeset
   104
     */     
hgs
parents:
diff changeset
   105
    virtual void StartSearchL( MEmailSearchObserver& aObserver ) = 0;
hgs
parents:
diff changeset
   106
hgs
parents:
diff changeset
   107
    /**
hgs
parents:
diff changeset
   108
     * Cancels search.
hgs
parents:
diff changeset
   109
     */
hgs
parents:
diff changeset
   110
    virtual void Cancel() = 0;
hgs
parents:
diff changeset
   111
                                             
hgs
parents:
diff changeset
   112
    /** returns search status 
hgs
parents:
diff changeset
   113
      * @return search status:
hgs
parents:
diff changeset
   114
      *     < 0 : Search has failed
hgs
parents:
diff changeset
   115
      *     KRequestPending : search is ongoing. note that status may be
hgs
parents:
diff changeset
   116
      *         KRequestPending after HandleResultL callback because results 
hgs
parents:
diff changeset
   117
      *         may be given in chunks of results. Size of chunk depends on
hgs
parents:
diff changeset
   118
      *         implementation and may vary.
hgs
parents:
diff changeset
   119
      *     KErrNone : initial state, or search has finished
hgs
parents:
diff changeset
   120
      */
hgs
parents:
diff changeset
   121
    virtual TInt Status() const = 0;
hgs
parents:
diff changeset
   122
    
hgs
parents:
diff changeset
   123
    /**
hgs
parents:
diff changeset
   124
     * Resets all search attribures. Cancels search if ongoing. 
hgs
parents:
diff changeset
   125
     */
hgs
parents:
diff changeset
   126
    virtual void Reset() = 0;
hgs
parents:
diff changeset
   127
};
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
} //EmailInterface
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
#endif // __MEMAILACTIONS
hgs
parents:
diff changeset
   132
hgs
parents:
diff changeset
   133
// End of file.