inc/unidatamodelplugininterface.h
changeset 31 ebfee66fde93
child 43 35b64624a9e7
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/inc/unidatamodelplugininterface.h	Fri Jun 04 10:25:39 2010 +0100
@@ -0,0 +1,258 @@
+/*
+ * Copyright (c) 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: This is the domain header API for general message data model
+ *              plugin behavior
+ */
+
+#ifndef UNIDATAMODELPLUGININTERFACE_H_
+#define UNIDATAMODELPLUGININTERFACE_H_
+
+#include <QtPlugin>
+#include <msvstd.h>
+#include <QDateTime>
+#include <msvapi.h>
+#include <cmsvattachment.h>
+#include "convergedmessageaddress.h"
+
+/**
+ * Enum defining Message  priority
+ * @attention This enum can have values from 0 to 2 only.
+ */
+enum MsgPriority
+{
+    Low = 0, Normal, High
+};
+
+/**
+ * UniMessageInfo
+ * Definition of Message's media objects
+ */
+
+class UniMessageInfo
+{
+public:
+    /**
+     * Constructor
+     */
+   inline  UniMessageInfo(const QString& filepath, const int size,
+                   const QString& mimetype);
+
+    /**
+     * Destructor
+     */
+    inline ~UniMessageInfo();
+
+    /**
+     * setPath
+     * @param file's path
+     */
+    inline void setPath(const QString& filepath);
+
+    /**
+     * setMimeType
+     * @param file's mimetype
+     */
+   inline void setMimeType(const QString& mimetype);
+
+    /**
+     * path
+     * @return file's path
+     */
+    inline const QString& path();
+
+    /**
+     * size
+     * @return file's size
+     */
+    inline const int size();
+
+    /**
+     * mimetype
+     * @return file's mimetype
+     */
+    inline const QString& mimetype();
+
+    /**
+     * Serialize the data memebers into the stream.
+     * @param stream data stream to which data is serialized.
+     */
+    inline void serialize(QDataStream &stream) const;
+
+    /**
+     * Deserialize the stream to data members.
+     * @param stream data stream from which data is deserialized.
+     */
+   inline void deserialize(QDataStream &stream);
+
+private:
+    QString mPath;
+    int mSize;
+    QString mMimeType;
+
+};
+
+
+typedef QList<UniMessageInfo*> UniMessageInfoList;
+
+class UniDataModelPluginInterface
+{
+public:
+
+    /**
+     * Destructor
+     */
+    virtual ~UniDataModelPluginInterface()
+    {
+    }
+
+    /**
+     * Creates the new instance of the plugin
+     * @return plugin instance
+     */    
+    virtual QObject* createInstance()=0;
+
+    /**
+     * Sets the id of the message whose details needs to be extacted.
+     * @param TMsvId of the message.
+     */
+
+    virtual int setMessageId(int messageId)=0;
+
+    /** Reset the datamodel
+     * Resets the data model to be used again
+     */
+    virtual void reset() =0;
+
+    /**
+     * Get the body of the message
+     * @param aBodyText , a QString to hold the message body
+     */
+    virtual void body(QString& aBodyText)=0;
+
+    /**
+     * Size of the message
+     * @return message size
+     */
+    virtual int messageSize()=0;
+
+    /**
+     * List of the message To recipients 
+     * @param  mAddressList, list of all addresses in the message
+     */
+    virtual void toRecipientList(ConvergedMessageAddressList& mAddressList)=0;
+
+    /**
+     * List of the message CC recipients 
+     * @param  mAddressList, list of all addresses in the message
+     */
+    virtual void ccRecipientList(ConvergedMessageAddressList& mAddressList)=0;
+
+    /**
+     * List of the message  bCC recipients 
+     * @param  mAddressList, list of all addresses in the message
+     */
+    virtual void bccRecipientList(ConvergedMessageAddressList& mAddressList)=0;
+
+    /**
+     * The from address of a message
+     * @param messageAddress
+     */
+    virtual void fromAddress(QString& messageAddress)=0;
+
+    /**
+     * List of attachments in the message.
+     * @return the attachment list for the message.
+     */
+    virtual UniMessageInfoList attachmentList()=0;
+
+    /**
+     * Type of the message (SMS/MMS etc..)
+     * @return message type
+     */
+    virtual QString messageType()=0;
+
+    /**
+     * Priority of the message (low/medium/high)
+     * @return MsgPriority.
+     */
+    virtual MsgPriority messagePriority()=0;
+
+    /**
+     * Number of attachments with the message
+     * @return count of attachment
+     */
+    virtual int attachmentCount()=0;
+
+    /**
+     * To check if the message has attachments
+     * @return true/false
+     */
+
+    virtual bool hasAttachment()=0;
+
+    /**
+     * Number of objects asociated with a MMS message
+     * @return object count
+     */
+    virtual int objectCount()=0;
+
+    /**
+     * The MMS object list asociated with a MMS message
+     * @return object list 
+     */
+    virtual UniMessageInfoList objectList()=0;
+
+    /**
+     * Number of slides asociated with a MMS message
+     * @return slide count
+     */
+    virtual int slideCount()=0;
+
+    /**
+     * The content of a Slide in case of a MMS message
+     * @param list of messageinfo objects.
+     */
+    virtual UniMessageInfoList slideContent(int count)=0;
+
+    /**
+     * Time stamp of the message when it was created/received.
+     * @param message time
+     */
+    virtual QDateTime timeStamp()=0;
+
+    /**
+     *  Restores the model for editing purpose
+     *  @param CBaseMtm
+     */        
+    virtual void restore(CBaseMtm& mtm)=0;
+	
+		/**
+     * Subject associated with the message
+     * @return QString
+     */
+		virtual QString subject()=0;
+	
+		/**
+     * Session with the Messaging Server 
+     * @return CMsvSession*
+     */
+		virtual CMsvSession* session() =0;
+};
+
+Q_DECLARE_INTERFACE(UniDataModelPluginInterface,
+        "org.nokia.messaging.UniDataModelPluginInterface/1.0")
+
+#include "unidatamodelplugininterface.inl"
+
+#endif //UNIDATAMODELPLUGININTERFACE_H_