logsui/logsengine/src/logsmessage.cpp
changeset 0 4a5361db8937
child 8 6c9acdc6adc0
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/logsui/logsengine/src/logsmessage.cpp	Tue May 04 12:39:37 2010 +0300
@@ -0,0 +1,157 @@
+/*
+* 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:
+*
+*/
+
+//USER
+#include "logsmessage.h"
+#include "logslogger.h"
+#include "logseventdata.h"
+#include <xqservicerequest.h>
+
+//SYSTEM
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+LogsMessage::LogsMessage(LogsEvent& event)
+    :QObject(), mIsAllowed( false ), mContactId( 0 ), mService( 0 )
+{
+    if ( event.logsEventData() && !event.logsEventData()->isCsCompatible() ){
+        LOGS_QDEBUG( "logs [ENG]    LogsMessage::LogsMessage, not CS compatible" )
+        mIsAllowed = false;
+    } else {
+        mIsAllowed = true;
+        mNumber = event.getNumberForCalling();
+        mContactId = event.contactLocalId();
+        mDisplayName = event.remoteParty();
+    }
+    
+}
+
+// -----------------------------------------------------------------------------
+//
+// -----------------------------------------------------------------------------
+//
+LogsMessage::LogsMessage(unsigned int contactId, const QString& number,
+	 const QString& displayName)
+    :QObject(), mIsAllowed( false ), mContactId( 0 ), mService( 0 )
+{
+    if ( number.length() == 0 ){
+        LOGS_QDEBUG( "logs [ENG]    LogsMessage::LogsMessage, not CS compatible" )
+        mIsAllowed = false;
+    } else {
+        mIsAllowed = true;
+        mNumber = number;
+        mContactId = contactId;
+        mDisplayName = displayName;
+    }
+}
+
+// -----------------------------------------------------------------------------
+// 
+// -----------------------------------------------------------------------------
+//
+LogsMessage::~LogsMessage()
+{
+    LOGS_QDEBUG( "logs [ENG] <-> LogsMessage::~LogsMessage()" )
+    delete mService;
+}
+    
+// ----------------------------------------------------------------------------
+// 
+// ----------------------------------------------------------------------------
+//
+bool LogsMessage::isMessagingAllowed()
+{
+    return mIsAllowed;
+}    
+
+// ----------------------------------------------------------------------------
+//
+// ----------------------------------------------------------------------------
+//
+bool LogsMessage::sendMessage()
+{
+    LOGS_QDEBUG( "logs [ENG] -> LogsMessage::sendMessage()" )
+    
+    delete mService;
+    mService = 0;
+    mService = new XQServiceRequest("com.nokia.services.hbserviceprovider.conversationview", 
+                                    "send(QString,qint32,QString)", false);
+    bool sending = doSendMessageToNumber(*mService, mNumber, mDisplayName, mContactId);
+    connect(mService, SIGNAL(requestCompleted(QVariant)), this, SLOT(requestCompleted(QVariant)));
+    connect(mService, SIGNAL(requestError(int)), this, SLOT(requestError(int)));
+    return sending;
+}
+
+// ----------------------------------------------------------------------------
+//
+// ----------------------------------------------------------------------------
+//
+bool LogsMessage::sendMessageToNumber(
+        const QString& number, const QString& displayName, unsigned int contactId)
+{
+    LOGS_QDEBUG( "logs [ENG] -> LogsMessage::sendMessageToNumber()" )
+    
+    XQServiceRequest req("com.nokia.services.hbserviceprovider.conversationview", 
+                         "send(QString,qint32,QString)", false);
+    return doSendMessageToNumber(req, number, displayName, contactId);
+}
+
+// ----------------------------------------------------------------------------
+//
+// ----------------------------------------------------------------------------
+//
+void LogsMessage::requestCompleted(const QVariant& /*value*/)
+{
+    LOGS_QDEBUG( "logs [ENG] -> LogsMessage::requestCompleted()" )
+}
+
+// ----------------------------------------------------------------------------
+//
+// ----------------------------------------------------------------------------
+//
+void LogsMessage::requestError(int /*err*/)
+{
+    LOGS_QDEBUG( "logs [ENG] -> LogsMessage::requestError()" )
+}
+
+// ----------------------------------------------------------------------------
+//
+// ----------------------------------------------------------------------------
+//
+bool LogsMessage::doSendMessageToNumber(
+        XQServiceRequest& request, const QString& number, 
+        const QString& displayName, unsigned int contactId)
+{
+    LOGS_QDEBUG_4( "logs [ENG] -> LogsMessage::doSendMessageToNumber(), (num, name, id)", 
+            number, displayName, contactId )
+
+    QList<QVariant> arguments;
+    arguments.append(QVariant(number));
+    arguments.append(QVariant(contactId));
+    arguments.append(QVariant(displayName));
+    request.setArguments(arguments);
+    QVariant retValue;
+    bool ret = request.send(retValue);
+    LOGS_QDEBUG_2( "logs [ENG] <- LogsMessage::doSendMessageToNumber()", ret )
+    
+    return ret;
+}
+
+// End of file
+