--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/phonebookengines/contactsmodel/cntmodel/inc/rcntmodel.h Tue Feb 02 10:12:17 2010 +0200
@@ -0,0 +1,215 @@
+/**
+* Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+
+
+/**
+ @file
+ @internalComponent
+ @released
+*/
+
+
+#ifndef RCNTMODEL_H
+#define RCNTMODEL_H
+
+#include <cntdb.h>
+#include "CCntIpcCodes.h"
+
+#include <e32base.h>
+#include <f32file.h>
+#include <badesca.h>
+
+
+class CContactTemplate;
+class CViewContact;
+class CCntDbNotifyMonitor;
+class CCntPackager;
+class MContactDbObserver;
+class CContactDefaultViewDefinition;
+class CContactTextDef;
+
+const TInt KUidBufferSize = 400;
+
+/**
+Client-side Contacts Model session handle.
+*/
+class RCntModel : public RSessionBase
+ {
+public:
+ RCntModel();
+
+ void ConnectL();
+ void Close();
+
+ TInt OpenDatabase(const TDesC& aCntFile = KNullDesC) const;
+ void OpenDatabaseAsyncL(TRequestStatus& aStatus ,const TDesC& aCntFile = KNullDesC);
+ void CancelAsyncOpen();
+
+ void OpenTablesL();
+ void CloseTablesL();
+
+ void CloseDatabase() const;
+ TInt ReplaceDatabase(const TDesC& aCntFile = KNullDesC) const;
+ TInt CreateDatabase(const TDesC& aCntFile = KNullDesC) const;
+ TInt DeleteDatabase(const TDesC& aCntFile = KNullDesC) const;
+
+ TInt DefaultDatabase(TDes& aCntFile) const;
+ TInt DatabaseDrive(TDriveUnit& aDriveUnit) const;
+ void SetDatabaseDriveL(TDriveUnit aDriveUnit, TBool aCopy = ETrue);
+ TBool DatabaseExistsL(const TDesC& aCntFile = KNullDesC) const;
+ CDesCArray* ListDatabasesL(TDriveUnit* aDriveUnit = NULL) const;
+ TPtrC FileUidL() const;
+ TBool DatabaseReadyL() const;
+
+ // Contact Item CRUD methods.
+ TContactItemId CreateContactL(CContactItem& aContact) const;
+ void DeleteContactL(const TContactItemId aCntId, TCntSendEventAction aCntEventType, TBool aDecAccessCount = EFalse) const;
+ void CommitContactL(const CContactItem& aContact, TBool aSendChangedEvent = ETrue) const;
+ CContactItem* ReadContactL(const CContactItemViewDef* aCntItemVDef, TContactItemId aCntId) const;
+ CContactItem* OpenContactLX(const CContactItemViewDef* aCntItemVDef, TContactItemId aCntId) const;
+ TBool CloseContact(TContactItemId aContactId);
+ void SetViewDefinitionL(const CContactViewDef& aView);
+
+ TInt64 MachineId() const;
+ void SetOperationTimeOutL(const TInt aMicroSeconds) const;
+ TInt OpenCrud() const;
+ TInt OpenIterator() const;
+ TInt OpenProperties() const;
+ TInt CloseCrud() const;
+ TInt CloseIterator() const;
+ TInt CloseProperties() const;
+ void CrudAsyncOp(TInt aParam,TRequestStatus& aStatus) const;
+ TInt CrudSyncOp(TInt aParam) const;
+ void IteratorAsyncOp(TInt aParam,TRequestStatus& aStatus) const;
+ TInt IteratorSyncOp(TInt aParam) const;
+ void PropertiesAsyncOp(TInt aParam,TRequestStatus& aStatus) const;
+ TInt PropertiesSyncOp(TInt aParam) const;
+
+ TInt FileSize() const;
+ TInt ReCreateTemplate() const;
+
+ TInt BeginDbTransaction() const;
+ TInt CommitDbTransaction() const;
+ TInt RollbackDbTransaction() const;
+
+ // Observer methods for database event notifications.
+ void AddObserverL(MContactDbObserver& aObserver);
+ void RemoveObserver(const MContactDbObserver& aObserver);
+
+ void SetCurrentItem(TContactItemId aContactId) const;
+ TContactItemId CurrentItem() const;
+ TInt RemoveCurrentItem();
+ TInt GetCurrentDatabase(TDes& aDatabase) const;
+ TInt SetCurrentDatabase(const TDesC& aDatabase) const;
+ void ResetServerSpeedDialsL();
+ TContactItemId GetSpeedDialFieldL(TInt aSpeedDialPosition, TDes& aPhoneNumber);
+ void SetFieldAsSpeedDialL(TContactItemId aContactId, TInt aFieldIndex, TInt aSpeedDialPosition);
+ void RemoveSpeedDialFieldL(TContactItemId aContactId, TInt aSpeedDialPosition);
+ void SetOwnCardL(const CContactItem& aContact);
+
+ TContactItemId OwnCard() const;
+ TInt ConnectionId() const;
+ void OverrideMachineUniqueId(TInt64 aMachineUniqueId);
+ void SetHeapFailure(RHeap::TAllocFail aType, TInt aRate);
+ TInt ResourceCount();
+ TContactItemId PrefTemplateId() const;
+ void SetPrefTemplateL(const TContactItemId aContactId);
+
+ CContactIdArray* FetchTemplateListIdsL();
+ CContactIdArray* FetchGroupListIdsL();
+
+ CContactIdArray* CollectionL(TInt aCollectionType, TTime aTime=0,const TDesC& aGuid = KNullDesC);
+
+ void SetSortPreferenceL(const CArrayFix<CContactDatabase::TSortPref>& aSortOrder);
+ CArrayFix<CContactDatabase::TSortPref>* GetSortPreferenceL() const;
+ CContactIdArray* MatchPhoneNumberL(const TDesC& aNumber, const TInt aMatchLengthFromRight);
+
+ TInt ContactCountL() const;
+
+ TBool SeekContactL(TContactItemId aContactId,TContactItemId& aId,TUid& aContactType, TBool& aDeleted);
+ void ReadContactTextDefL(TContactItemId aContactId, TDes &aResult,const CContactTextDef& aTextDef);
+
+ void TextFieldL(TInt aCntItemId,TFieldType aFieldType, TDes& aText);
+
+ TContactItemId ICCTemplateIdL(TUid aPhonebookUid = KNullUid);
+ TContactItemId PhonebookGroupIdL();
+
+ CContactIdArray* FindL(const TDesC& aText,const CContactItemFieldDef* aFieldDef);
+
+ TBool ContactMatchesHintFieldL(TInt aBitWiseFilter,TContactItemId aContactId);
+
+ void SetDbViewContactType(const TUid aUid);
+ TUid GetDbViewContactType() const;
+
+ void FilterDatabaseL(CCntFilter& aFilter);
+
+ void FindAsyncTextDefInitL(const CDesCArray& aWords,CContactTextDef* aTextDef);
+ void FindAsyncInitL(const TDesC& aText,CContactItemFieldDef* aFieldDef);
+ TBool FindAsyncL(CContactIdArray*& aIdArray);
+
+ void SetAsyncActivityL(TBool aAsyncActivity);
+
+ // Used to request a database event. See CCntDbNotifyMonitor::Start().
+ void StartNotificationTransfer(TRequestStatus& aStatus, TDes8& aEvent);
+ void EndNotificationTransfer();
+
+ // See CCntDbNotifyMonitor::RunL().
+ void HandlePrematureServerTerminationL();
+
+ // Used to close/unlock the last locked contact items from the cleanup
+ // stack. Called when popping the cleanup stack.
+ void UnlockLastLockedContact();
+
+ // Used for test purposes (only works in _DEBUG builds).
+ void GetDefinitionsOfExistingViewsL(const TDesC& aDbName, RPointerArray<CContactDefaultViewDefinition>& aViewDefs);
+
+ TInt OpenViewL(const CContactTextDef& aTextDef, const TInt aViewPrefs);
+ void CloseView(TInt aViewId);
+ void ChangeSortOrderL(TInt aViewId, const CContactTextDef& aTextDef);
+ void BeginIterateL(TInt aViewId);
+ void EndIterateL(TInt aViewId);
+ CViewContact* NextItemL(TInt aViewId, const TInt aViewPrefs);
+ CViewContact* ItemAtL(TContactItemId aContactId, TInt aViewId);
+
+private:
+ TVersion Version() const;
+ CContactItem* UnPackContactLC(TInt aBufferSize, TIpcArgs& aArgs) const;
+
+ CContactIdArray* DoGetCollectionChangedSinceL(TTime aTime);
+ CContactIdArray* DoGetCollectionL(TInt aCollectionType);
+ CContactIdArray* DoGetCollectionGuidL(const TDesC& aGuid);
+ void PushUnlockL() const;
+
+ // Save the filename. Used to re-open database if the server is terminated
+ // prematurely.
+ TInt SetFileName(const TDesC& aCntFile) const;
+
+private:
+ CCntDbNotifyMonitor* iDbNotifyMonitor;
+ mutable CCntPackager* iPackager;
+
+ mutable TBuf<KUidBufferSize> iFileUid;
+ mutable TInt iConnectionId;
+ mutable TBuf<KCntMaxFilePath> iFileName;
+
+ // Number of attempts to restart the server after an unexpected process
+ // termination.
+ TInt iNoOfSvrStartAttempts;
+ };
+
+#endif // RCNTMODEL_H