serviceproviders/sapi_calendar/inc/calendarinterface.h
author andy.simpson <andrews@symbian.org>
Tue, 15 Dec 2009 14:31:48 +0000
changeset 22 76eb2bdc9c63
parent 10 fc9cf246af83
child 23 50974a8b132e
permissions -rw-r--r--
Added tag PDK_3.0.d for changeset 8d692d9f828f

/*
* Copyright (c) 2007 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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:  Defination of class CCalendarInterface
*
*/


#ifndef __CALENDARINTERFACE_H
#define __CALENDARINTERFACE_H

#include <LiwCommon.h>
#include <LiwServiceIfBase.h>
#include <LiwBufferExtension.h>

#include <calrrule.h>
#include <calalarm.h>
#include <caluser.h>
#include <calentry.h>
#include <calchangecallback.h>

#include "calendarheader.h"
#include "calendarconstants.h"

class CCalendarService;
class CIterableCalEntryList;
class CEntryAttributes;
class TUIDSet;

/**
 * This class provides the Calendar SAPI interface to LIW Framework 
*/
class CCalendarInterface : public CBase, public MLiwInterface
	{
		
	public:

	    /**
	     * Two-phased constructor.
	     * @return CCalendarInterface* 
	    */
		static CCalendarInterface* NewL();

	    /**
	    * Destructor.
	    */
		virtual ~CCalendarInterface();

	private:

		/**
	     * Constructor
	    */
		CCalendarInterface();

		/**
	     * Symbian Constructor
	    */
		void ConstructL();

	// MLiwInterface member functions
	public:

		/**
	     * Executes the SAPI as per params
	     * @param aCmdName Command name defining which operation is to be performed
	     * @param aInParamList  Input param list
	     * @param aOutParamList Output list
	     * @param aCmdOptions Command option
	     * @param aCallback Callback object pointer
	    */
		virtual void ExecuteCmdL( const TDesC8& aCmdName,
		                       const CLiwGenericParamList& aInParamList,
		                       CLiwGenericParamList& aOutParamList,
		                       TUint aCmdOptions = 0,
		                       MLiwNotifyCallback* aCallback = 0 );
		
		/**
	     * Closes the interface 
	    */
		virtual void Close();
		
	/**
     * Static Functions
	 * 
	 * Same functionality required outside the CCalendarInterface class in case of async
	 * operation. Those set of functions can be given as static.
    */
	public:
 
		/**
	     * Converts symbian errcode to equivalent SAPI error code
	     * @param aErrorCode Symbian error code
		 *
	     * @return mapped SAPI error code
	    */
 		static TInt32 ErrCodeConversion(TInt aErrorCode);

		/**
	     * Set Import output to output parameter
	     * @param aOutputUIDSet Import output
	     * @param aOutParamList Output parammeter
		 *
	     * @return void
	    */
		static void SetImportOutputL( RPointerArray<TUIDSet>& aOutputUIDSet, 
												CLiwGenericParamList& aOutParamList );

        /**
         * Set Getlist output to output parameter
         * @param aOutputCalEntry getlist output
         * @param aOutParamList Output parammeter
         *
         * @return void
        */
        void SetCalEntryOutputL( RPointerArray<CCalEntry>& aOutputCalEntry, 
                                                CLiwGenericParamList& aOutParamList, 
                                                const TDesC& aCalendarName );
        /**
         * Set Getlist output to output parameter
         * @param aOutputCalEntry getlist output
         * @param aOutParamList Output parammeter
         *
         * @return void
        */
        void SetCalInstanceOutputL( RPointerArray<CCalInstance>& aOutputCalEntry, 
                                                CLiwGenericParamList& aOutParamList, 
                                                const TDesC& aCalendarName );
        
		
		/**
	     * Set Change Notification output to output parameter
	     * @param aOutputChangeSet Notifications list
	     * @param aOutParamList Output parammeter
		 *
	     * @return void
	    */
		static void SetNotifyOutputL( RArray<TCalChangeEntry>& aOutputChangeSet,  
												CLiwGenericParamList& aOutParamList );
		
		/**
	     * Set GlobalUid/LocalUid to the LiwVariant
	     * @param aReturnValue Variant to be set
	     * @param aUIDSet GlobalUid/LocalUid
		 *
	     * @return void
	    */
		static void GetTLiwVariantForUIDSetL( TLiwVariant& aReturnValue, TUIDSet* aUIDSet );

		/**
	     * Set Change type to the LiwVariant
	     * @param aValue Variant to be set
	     * @param aChangeEntry Change Type
		 *
	     * @return void
	    */
		static void GetTLiwVariantForCalChangeEntryL( TLiwVariant& aValue, 
												TCalChangeEntry& aChangeEntry );

		/**
	     * Cleanup function for an CIterableCalEntryList
	     * @param aIterEntryList CIterableCalEntryList pointer
		 *
	     * @return void
	    */
		static void CleanupIterableCalEntry(void* aIterEntryList);

		/**
	     * Returns Day of Month of repeat rule as LiwVariant Map. Caller takes the ownership of map
	     * @param aDayOfMonth Day of Month
		 *
	     * @return CLiwDefaultMap* LiwMap object
	    */
		static CLiwDefaultMap* GetDayOfMonthL( const TCalRRule::TDayOfMonth&  aDayOfMonth );

		/**
	     * Returns CalUser as LiwVariant Map. Caller takes the ownership of map
	     * @param aCalUser Day of Month
	     * @param aAttendee True if User is an attendee
		 *
	     * @return CLiwDefaultMap* LiwMap object
	    */
		static CLiwDefaultMap* GetCalUserL( CCalUser* aCalUser, TBool aAttendee = EFalse );

		/**
	     * Returns array of CalTime as LiwVariant List. Caller takes the ownership of list
	     * @param aDates Array of CalTime 
		 *
	     * @return CLiwDefaultList* LiwList object
	    */
		static CLiwDefaultList* GetDatesListL( RArray<TCalTime>& aDates ) ;

		/**
	     * Returns RepeatRule as LiwVariant Map. Caller takes the ownership of map
	     * @param aRepeatRule Repeat Rule
		 *
	     * @return CLiwDefaultMap* LiwMap object
	    */
		static CLiwDefaultMap* GetRRMapL( const TCalRRule& aRepeatRule );

		/**
	     * Returns string literal for the given Entry Type
	     * @param aType Entry Type
		 *
	     * @return TPtrC Entry Type string
	    */
		static TPtrC GetEntryTypeL( const CCalEntry::TType aType );

		/**
	     * Returns string literal for the given Entry Replication status
	     * @param aReplicationStatus Replication status
		 *
	     * @return TPtrC Replication status string
	    */
		static TPtrC GetReplicationL( const CCalEntry::TReplicationStatus aReplicationStatus );

		/**
	     * Returns string literal for Change Types
	     * @param aChangeType Change Type
		 *
	     * @return TPtrC Change Type
	    */
		static TPtrC GetChangeType( const MCalChangeCallBack2::TChangeType aChangeType );

		/**
	     * Returns string literal for Entry Status
	     * @param aStatus Entry Status
		 *
	     * @return TPtrC Entry Status
	    */
		static TPtrC GetStatusL( const CCalEntry::TStatus aStatus );

		/**
	     * Returns string literal for Attendee Status
	     * @param aStatus Attendee Status
		 *
	     * @return TPtrC Attendee Status
	    */
		static TPtrC GetAttendeeStatusL( const CCalAttendee::TCalStatus aStatus );

		/**
	     * Get string literal for Attendee Role
	     * @param aRole Attendee Role
		 *
	     * @return TPtrC Attendee Role
	    */
		static TPtrC GetAttendeeRoleL( const CCalAttendee::TCalRole aRole );

		/**
	     * Return string literal for Entry Method
	     * @param aMethod Entry Method
		 *
	     * @return TPtrC Entry Method
	    */
		static TPtrC GetMethodL( const CCalEntry::TMethod aMethod );

		/**
	     * Removes the reference of CIterableCalEntryList from the table maintained 
	     * by interface
	     * @param aCalEntryList Element that need to be removed from the table
		 *
	     * @return void
	    */
		void RemoveCalEntryListFromArray( CIterableCalEntryList* aCalEntryList );


	private:
	
		/**
	     * Issues Add Calendar request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aOutParamList Output param list
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return void
	    */
		void AddCalendarL(const CLiwGenericParamList& aInParamList, 
												CLiwGenericParamList& aOutParamList, 
												const TBool aPosBased );
		
		/**
	     * Issues Add Calendar Entry request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aOutParamList Output param list
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return void
	    */
		void AddCalendarEntryL(const CLiwGenericParamList& aInParamList, 
												CLiwGenericParamList& aOutParamList, 
												const TBool aPosBased );

		/**
	     * Issues Delete Calendar request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aOutParamList Output param list
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return void
	    */
		void DeleteCalendarL( const CLiwGenericParamList& aInParamList, TBool aPosBased);
		
		/**
	     * Issues Delete Calendar Entry request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aOutParamList Output param list
	     * @param aCmdOptions Command option
	     * @param aCallback Callback object pointer
	     * @param aPosBased ETrue for position pased parameters
	     * @param aTransactionId Output param for async request to store transaction id
		 *
	     * @return void
	    */
		void DeleteCalendarEntryL(const CLiwGenericParamList& aInParamList, 
												CLiwGenericParamList& aOutParamList,
												TUint aCmdOptions,
				                       			MLiwNotifyCallback* aCallback ,
												const TBool aPosBased,
												TInt32& aTransactionId  );

		/**
	     * Issues GetList Calendar request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aOutParamList Output param list
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return void
	    */
		void GetListCalendarL(const CLiwGenericParamList& aInParamList, 
												CLiwGenericParamList& aOutParamList, 
												const TBool aPosBased );
		
		/**
	     * Issues GetList Calendar Entry request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aOutParamList Output param list
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return void
	    */
		void GetListCalendarEntryL(const CLiwGenericParamList& aInParamList, 
												CLiwGenericParamList& aOutParamList,
												TUint aCmdOptions,
												MLiwNotifyCallback* aCallback ,
												const TBool aPosBased,
												TInt32& aTransactionId  );
												
		/**
	     * Issues Import Calendar Entry request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aOutParamList Output param list
	     * @param aCmdOptions Command option
	     * @param aCallback Callback object pointer
	     * @param aPosBased ETrue for position pased parameters
	     * @param aTransactionId Output param for async request to store transaction id
		 *
	     * @return void
	    */
		void ImportCalendarEntryL(const CLiwGenericParamList& aInParamList, 
												CLiwGenericParamList& aOutParamList,
												TUint aCmdOptions,
				                       			MLiwNotifyCallback* aCallback ,
												const TBool aPosBased,
												TInt32& aTransactionId  );

		/**
	     * Issues Export Calendar Entry request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aOutParamList Output param list
	     * @param aCmdOptions Command option
	     * @param aCallback Callback object pointer
	     * @param aPosBased ETrue for position pased parameters
	     * @param aTransactionId Output param for async request to store transaction id
		 *
	     * @return void
	    */
		void ExportCalendarEntryL(const CLiwGenericParamList& aInParamList, 
												CLiwGenericParamList& aOutParamList,
												TUint aCmdOptions,
				                       			MLiwNotifyCallback* aCallback ,
												const TBool aPosBased,
												TInt32& aTransactionId  );
													
		/**
	     * Issues Change Notification request to Calendar Service
	     * @param aInParamList Input param list
	     * @param aCallback Callback object pointer
	     * @param aPosBased ETrue for position pased parameters
	     * @param aTransactionId Output param for async request to store transaction id
		 *
	     * @return void
	    */
		void RequestNotificationL( const CLiwGenericParamList& aInParamList, 
				                       			MLiwNotifyCallback* aCallback,
												const TBool aPosBased,
												TInt32& aTransactionId );



		/**
	     * Extracts LocalUid as TCalLocalUid from input Uid String
	     * @param aLocalUid Input string
	     * @param aOutLocalUid output param for LocalUid
		 *
	     * @return void
	    */
		void GetLocalUid( const TDesC& aLocalUid, TCalLocalUid& aOutLocalUid );
		
		/**
	     * Extracts GlobalUid as 8-bit string from input Uid String
	     * @param aGlobalUid Input string
	     * @param aOutGlobalUid output param for GlobalUid
		 *
	     * @return void
	    */
		void GetGlobalUid( const TDesC& aGlobalUid, TPtr8 aOutGlobalUid );

		/**
	     * Extracts ContentType from the input param list
	     * @param aInParamList Input param list
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return ContentType string
	    */
		TPtrC GetContentType(const CLiwGenericParamList& aInParamList, 
												TBool& aPosBased );
		
		/**
	     * Extracts TransactionId from the input param list
	     * @param aInParamList Input param list
	     * @param aTransactionId output param fromtransactiod id
		 *
	     * @return void
	    */
		void GetTransactionIdL( const CLiwGenericParamList& aInParamList, 
												TInt32& aTransactionId );

		/**
	     * Extracts CalendarName from the input param list
	     * @param aInParamList Input param list
	     * @param aCmdName Command Name
	     * @param aField ParameterName to read
	     * @param aPosBased ETrue for position pased parameters
	     * @param aCalendarName Output param for Calendar Name
		 *
	     * @return void
	    */
	    void GetCalendarNameL( const CLiwGenericParamList& aInParamList,
	    										const TDesC8& aCmdName,  
	    										const TDesC8& aField, 
	    										TBool aPosBased, 
	    										HBufC*& aCalendarName );

		/**
	     * Extracts Descriptor Field from Map in input param list
	     * @param aInParamList Input param list
	     * @param aCmdName Command Name
	     * @param aMapName Map name in input param list
	     * @param aFieldName Filed name to read from map
	     * @param aPosBased ETrue for position pased parameters
	     * @param aOutputField Output param for Field value
		 *
	     * @return void
	    */
		void CCalendarInterface::GetDesCFieldFromMapL( const CLiwGenericParamList& aInParamList, 
														const TDesC8& aCmdName, 
														const TDesC8& aMapName, 
														const TDesC8& aFieldName, 
														TBool aPosBased, 
														HBufC*& aOutputField );

		/**
	     * Extracts 8-bit Descriptor Field from Map in input param list
	     * @param aInParamList Input param list
	     * @param aCmdName Command Name
	     * @param aMapName Map name in input param list
	     * @param aFieldName Filed name to read from map
	     * @param aPosBased ETrue for position pased parameters
	     * @param aOutputField Output param for Field value
		 *
	     * @return void
	    */
		void CCalendarInterface::GetDesC8FieldFromMapL( const CLiwGenericParamList& aInParamList, 
														const TDesC8& aCmdName, 
														const TDesC8& aMapName, 
														const TDesC8& aFieldName, 
														TBool aPosBased, 
														HBufC8*& aOutputField );

		/**
	     * Extracts Entry attributes for Add/Update request
	     * @param aInParamList Input param list
	     * @param aCalendarName CalendarName
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return CEntryAttributes* EntryAttributes object
	    */
		CEntryAttributes* GetAddParametersL( const CLiwGenericParamList& aInParamList, 
												const TDesC& aCalendarName,
												TBool aPosBased);
		
		/**
	     * Extracts Filter for Delete request
	     * @param aInParamList Input param list
	     * @param aFilter Output param for Filter
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return void
	    */
		void GetDeleteEntryFilterL(const CLiwGenericParamList& aInParamList, 
												CCalendarFilter& aFilter, 
												const TBool aPosBased );

		/**
	     * Extracts Inputs for Import request
	     * @param aInParamList Input param list
	     * @param aPosBased ETrue for position pased parameters
	     * @param aInputBuffer Output param for Buffer from which entries to be imported
	     * @param aImportFile Output param for File from which entries to be imported
	     * @param aCalendarFormat Output param for Calendar Format to be used (ICal/VCal)
	     * @param aCalendarName Output param for Calendar Name
		 *
	     * @return void
	    */
		void GetImportInputL( const CLiwGenericParamList& aInParamList,
												TBool    aPosBased, 
												HBufC8*& aInputBuffer, 
												TDes&   aImportFile,
												TDes8&  aCalendarFormat, 
												TDes&   aCalendarName );

		/**
	     * Extracts Inputs for Export request
	     * @param aInParamList Input param list
	     * @param aPosBased ETrue for position pased parameters
	     * @param aCalExportParams Output param for Export parameters
		 *
	     * @return void
	    */
		void GetExportInputL( const CLiwGenericParamList& aInParamList, 
												TBool                  aPosBased, 
												CCalendarExportParams& aCalExportParams);							  
	
		/**
	     * Extracts Inputs for Change Notification request
	     * @param aInParamList Input param list
	     * @param aFileter Output param for Change Notification filter
	     * @param aPosBased ETrue for position pased parameters
		 *
	     * @return void
	    */
		void GetNotificationFilterL( const CLiwGenericParamList& aInParamList, 
												CCalendarFilter& aFilter, 
												const TBool aPosBased );
												
		/**
	     * Appends error message
	     * @param aCmdName Command Name
	     * @param aParameter Parameter Name
	     * @param aMessage Error message
		 *
	     * @return void
	    */
		void AppendErrorMessageL( const TDesC8& aCmdName, 
												const TDesC8& aParameter, 
												const TDesC& aMessage );
												
		/**
	     * Checks for the valid data type of Parameter.
	     * @param aParam Input parameter
	     * @param aExpectedtype Expected type for input parameter
	     * @param aCmdName Command Name
	     * @param aParameter Parameter Name
	     * @param aErrorMessage Error message in case of type mismatch
		 *
	     * @return void
	    */
		void ValidateParamTypeL( TLiwVariant& aParam, 
												LIW::TVariantTypeId aExpectedtype, 
												const TDesC8& aCmdName, 
												const TDesC8& aParameter,
												const TDesC& aMessage );

		/**
	     * Returns entry type for given LocalUid.
	     * @param aCalendarName CalendarName
	     * @param aLocalUid LocalUid
		 *
	     * @return Entry type
	    */
		TInt GetEntryType( const TDesC& aCalendarName, TCalLocalUid aLocalUid );
        /**
         * Returns entry type for given LocalUid.
         * @param aCalendarName CalendarName
         * @param aLocalUid LocalUid
         *
         * @return Entry type
        */
        TInt GetEntryType( const TDesC& aCalendarName, const TDesC8& aGuid );
		
		
		/**
	     * Check if given calendar is in use.
	     * @param aCalendarName CalendarName
		 *
	     * @return True if given calendar is in use
	    */
		TBool CCalendarInterface::CheckCalendarInUse( const TDesC& aCalendarName );
		
	private:

	  	/**
	     * CCalendarService class pointer
	     * @internal
	    */		
		CCalendarService* iCalService;

	  	/**
	     * Error Message object
	     * @internal
	    */		
		HBufC* iErrorMessage;

	  	/**
	     * Array containing the list of CalEntryList.
	     * @internal
	    */		
		RPointerArray<CIterableCalEntryList> iArrayCalEntryList;

	};


#endif __CALENDARINTERFACE_H