phonebookengines/contactsmodel/cntmodel/inc/rcntmodel.h
changeset 0 e686773b3f54
child 24 0ba2181d7c28
--- /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