contentstorage/castorage/inc/castorage.h
author hgs
Tue, 23 Mar 2010 23:28:12 +0200
changeset 86 e492551a0d54
parent 85 7feec50967db
child 94 dbb8300717f7
permissions -rw-r--r--
201005
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
85
7feec50967db 201003_02
hgs
parents:
diff changeset
     1
/*
7feec50967db 201003_02
hgs
parents:
diff changeset
     2
 * Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
7feec50967db 201003_02
hgs
parents:
diff changeset
     3
 * All rights reserved.
7feec50967db 201003_02
hgs
parents:
diff changeset
     4
 * This component and the accompanying materials are made available
7feec50967db 201003_02
hgs
parents:
diff changeset
     5
 * under the terms of "Eclipse Public License v1.0"
7feec50967db 201003_02
hgs
parents:
diff changeset
     6
 * which accompanies this distribution, and is available
7feec50967db 201003_02
hgs
parents:
diff changeset
     7
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
7feec50967db 201003_02
hgs
parents:
diff changeset
     8
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
     9
 * Initial Contributors:
7feec50967db 201003_02
hgs
parents:
diff changeset
    10
 * Nokia Corporation - initial contribution.
7feec50967db 201003_02
hgs
parents:
diff changeset
    11
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    12
 * Contributors:
7feec50967db 201003_02
hgs
parents:
diff changeset
    13
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    14
 * Description:
7feec50967db 201003_02
hgs
parents:
diff changeset
    15
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    16
 */
7feec50967db 201003_02
hgs
parents:
diff changeset
    17
7feec50967db 201003_02
hgs
parents:
diff changeset
    18
#ifndef C_CASTORAGE_H
7feec50967db 201003_02
hgs
parents:
diff changeset
    19
#define C_CASTORAGE_H
7feec50967db 201003_02
hgs
parents:
diff changeset
    20
7feec50967db 201003_02
hgs
parents:
diff changeset
    21
#include "caoperationparams.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    22
7feec50967db 201003_02
hgs
parents:
diff changeset
    23
// FORWARD DECLARATIONS
7feec50967db 201003_02
hgs
parents:
diff changeset
    24
class CCaInnerQuery;
7feec50967db 201003_02
hgs
parents:
diff changeset
    25
class CCaInnerEntry;
7feec50967db 201003_02
hgs
parents:
diff changeset
    26
class CCaLocalizationEntry;
7feec50967db 201003_02
hgs
parents:
diff changeset
    27
/**
7feec50967db 201003_02
hgs
parents:
diff changeset
    28
 *  @ingroup group_catorage.
7feec50967db 201003_02
hgs
parents:
diff changeset
    29
 *  Interface for storage.
7feec50967db 201003_02
hgs
parents:
diff changeset
    30
 */
7feec50967db 201003_02
hgs
parents:
diff changeset
    31
class CCaStorage: public CBase
7feec50967db 201003_02
hgs
parents:
diff changeset
    32
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
    33
public:
7feec50967db 201003_02
hgs
parents:
diff changeset
    34
7feec50967db 201003_02
hgs
parents:
diff changeset
    35
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
    36
     * Localizes one entry attribute.
7feec50967db 201003_02
hgs
parents:
diff changeset
    37
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
    38
     * @param aLocalization localization information about entry.
7feec50967db 201003_02
hgs
parents:
diff changeset
    39
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
    40
    virtual void LocalizeEntryL( CCaLocalizationEntry& aLocalization ) = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    41
7feec50967db 201003_02
hgs
parents:
diff changeset
    42
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
    43
     * Fetches data from database
7feec50967db 201003_02
hgs
parents:
diff changeset
    44
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
    45
     * @param aResultContainer container for localizations information.
7feec50967db 201003_02
hgs
parents:
diff changeset
    46
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
    47
    virtual void GetLocalizationsL( RPointerArray<CCaLocalizationEntry>& aResultContainer ) = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    48
7feec50967db 201003_02
hgs
parents:
diff changeset
    49
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
    50
     * Fetches data from database.
7feec50967db 201003_02
hgs
parents:
diff changeset
    51
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
    52
     * @param aQuery The query information to select specific entries.
7feec50967db 201003_02
hgs
parents:
diff changeset
    53
     * @param aResultContainer The result list of entries .
7feec50967db 201003_02
hgs
parents:
diff changeset
    54
     * for a specific select.
7feec50967db 201003_02
hgs
parents:
diff changeset
    55
     */
86
hgs
parents: 85
diff changeset
    56
    virtual void GetEntriesL( const CCaInnerQuery* aQuery,
85
7feec50967db 201003_02
hgs
parents:
diff changeset
    57
            RPointerArray<CCaInnerEntry>& aResultContainer ) = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    58
7feec50967db 201003_02
hgs
parents:
diff changeset
    59
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
    60
     * Fetches data from database by ids.
7feec50967db 201003_02
hgs
parents:
diff changeset
    61
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
    62
     * @param aQuery The query information to select specific entries.
86
hgs
parents: 85
diff changeset
    63
     * @param aResultIdArray The result list of entries' ids.
85
7feec50967db 201003_02
hgs
parents:
diff changeset
    64
     * for a specific select.
7feec50967db 201003_02
hgs
parents:
diff changeset
    65
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
    66
    virtual void GetEntriesIdsL( const CCaInnerQuery* aQuery,
7feec50967db 201003_02
hgs
parents:
diff changeset
    67
            RArray<TInt>& aResultIdArray ) = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    68
7feec50967db 201003_02
hgs
parents:
diff changeset
    69
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
    70
     * Fetches parent id from database by entry ids.
7feec50967db 201003_02
hgs
parents:
diff changeset
    71
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
    72
     * @param aEntryIdArray list of enties ids.
7feec50967db 201003_02
hgs
parents:
diff changeset
    73
     * @param aParentIdArray The result list of parents' ids
7feec50967db 201003_02
hgs
parents:
diff changeset
    74
     * for a specific select.
7feec50967db 201003_02
hgs
parents:
diff changeset
    75
     */
86
hgs
parents: 85
diff changeset
    76
    virtual void GetParentsIdsL( const RArray<TInt>& aEntryIdArray,
85
7feec50967db 201003_02
hgs
parents:
diff changeset
    77
            RArray<TInt>& aParentIdArray ) = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    78
7feec50967db 201003_02
hgs
parents:
diff changeset
    79
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
    80
     * Adds or Updates data & action to the storage.
7feec50967db 201003_02
hgs
parents:
diff changeset
    81
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
    82
     * @param aEntry The entry data to be added or updated.
7feec50967db 201003_02
hgs
parents:
diff changeset
    83
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
    84
    virtual void AddL( CCaInnerEntry* aEntry, TBool aUpdate = EFalse ) = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    85
7feec50967db 201003_02
hgs
parents:
diff changeset
    86
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
    87
     * Removes data item from storage.
7feec50967db 201003_02
hgs
parents:
diff changeset
    88
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
    89
     * @param aEntryIds The entry ids to be removed.
7feec50967db 201003_02
hgs
parents:
diff changeset
    90
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
    91
    virtual void RemoveL( const RArray<TInt>& aEntryIds ) = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
    92
7feec50967db 201003_02
hgs
parents:
diff changeset
    93
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
    94
     * Organizes data within a group in the storage.
7feec50967db 201003_02
hgs
parents:
diff changeset
    95
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
    96
     * @param aEntryIds Ids of entries to organize.
7feec50967db 201003_02
hgs
parents:
diff changeset
    97
     * @param aParams Operation parameters to specify the organize type.
7feec50967db 201003_02
hgs
parents:
diff changeset
    98
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
    99
    virtual void OrganizeL( const RArray<TInt>& aEntryIds,
7feec50967db 201003_02
hgs
parents:
diff changeset
   100
            TCaOperationParams aParams ) = 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
   101
7feec50967db 201003_02
hgs
parents:
diff changeset
   102
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
   103
     * Stores touch data information in storage.
7feec50967db 201003_02
hgs
parents:
diff changeset
   104
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
   105
     * @param aEntryId The entry id for which touch data should be stored.
7feec50967db 201003_02
hgs
parents:
diff changeset
   106
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
   107
    virtual void TouchL( const TInt aEntryId ) = 0;
86
hgs
parents: 85
diff changeset
   108
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   109
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
   110
     * Get database property from db.
7feec50967db 201003_02
hgs
parents:
diff changeset
   111
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
   112
     * @param aProperty The property to get.
7feec50967db 201003_02
hgs
parents:
diff changeset
   113
     * @param aPropertyValue The value of property.
7feec50967db 201003_02
hgs
parents:
diff changeset
   114
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
   115
    virtual void DbPropertyL( const TDesC& aProperty, TDes& aPropertyValue ) = 0;
86
hgs
parents: 85
diff changeset
   116
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   117
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
   118
     * Set property .
7feec50967db 201003_02
hgs
parents:
diff changeset
   119
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
   120
     * @param aProperty The property to set.
7feec50967db 201003_02
hgs
parents:
diff changeset
   121
     * @param aPropertyValue The value of property.
7feec50967db 201003_02
hgs
parents:
diff changeset
   122
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
   123
    virtual void SetDBPropertyL( const TDesC& aProperty, const TDesC& aPropertyValue ) = 0;
86
hgs
parents: 85
diff changeset
   124
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   125
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
   126
     * Remove from localization table .
7feec50967db 201003_02
hgs
parents:
diff changeset
   127
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
   128
     * @param aEntryId Entry Id to remove.
7feec50967db 201003_02
hgs
parents:
diff changeset
   129
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
   130
    virtual void RemoveFromLocalizationL( const TInt aEntryId ) = 0;
86
hgs
parents: 85
diff changeset
   131
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   132
    /**
7feec50967db 201003_02
hgs
parents:
diff changeset
   133
     * Organizes data within a group in custom order.
7feec50967db 201003_02
hgs
parents:
diff changeset
   134
     *
7feec50967db 201003_02
hgs
parents:
diff changeset
   135
     * @param aEntryIds Ids of entries in custom order.
7feec50967db 201003_02
hgs
parents:
diff changeset
   136
     * @param aGroupId Group to sort.
7feec50967db 201003_02
hgs
parents:
diff changeset
   137
     */
7feec50967db 201003_02
hgs
parents:
diff changeset
   138
    virtual void CustomSortL( const RArray<TInt>& aEntryIds,
86
hgs
parents: 85
diff changeset
   139
            const TInt aGroupId ) = 0;
hgs
parents: 85
diff changeset
   140
hgs
parents: 85
diff changeset
   141
    /**
hgs
parents: 85
diff changeset
   142
     * Loads data base from rom.
hgs
parents: 85
diff changeset
   143
     */
hgs
parents: 85
diff changeset
   144
    virtual void LoadDataBaseFromRomL() = 0;
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   145
7feec50967db 201003_02
hgs
parents:
diff changeset
   146
    };
7feec50967db 201003_02
hgs
parents:
diff changeset
   147
7feec50967db 201003_02
hgs
parents:
diff changeset
   148
#endif //C_CASTORAGE_H