2018-09-10 10:28:54 +01:00
|
|
|
/**
|
|
|
|
* Copyright 2013 Albert Vaca <albertvaka@gmail.com>
|
2018-10-06 01:01:30 +01:00
|
|
|
* Copyright 2018 Simon Redman <simon@ergotech.com>
|
2018-09-10 10:28:54 +01:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2 of
|
|
|
|
* the License or (at your option) version 3 or any later version
|
|
|
|
* accepted by the membership of KDE e.V. (or its successor approved
|
|
|
|
* by the membership of KDE e.V.), which shall act as a proxy
|
|
|
|
* defined in Section 14 of version 3 of the license.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2019-03-23 16:29:26 +00:00
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2018-09-10 10:28:54 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SMSPLUGIN_H
|
|
|
|
#define SMSPLUGIN_H
|
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
|
|
|
|
#include <core/kdeconnectplugin.h>
|
|
|
|
|
|
|
|
#include "conversationsdbusinterface.h"
|
|
|
|
#include "interfaces/conversationmessage.h"
|
|
|
|
|
|
|
|
#include "sendreplydialog.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Packet used to indicate a batch of messages has been pushed from the remote device
|
|
|
|
*
|
|
|
|
* The body should contain the key "messages" mapping to an array of messages
|
|
|
|
*
|
|
|
|
* For example:
|
2019-07-20 21:35:53 +01:00
|
|
|
* {
|
|
|
|
* "version": 2 // This is the second version of this packet type and
|
|
|
|
* // version 1 packets (which did not carry this flag)
|
|
|
|
* // are incompatible with the new format
|
|
|
|
* "messages" : [
|
2018-11-15 23:57:58 +00:00
|
|
|
* { "event" : 1, // 32-bit field containing a bitwise-or of event flags
|
|
|
|
* // See constants declared in SMSHelper.Message for defined
|
|
|
|
* // values and explanations
|
|
|
|
* "body" : "Hello", // Text message body
|
2019-07-20 21:35:53 +01:00
|
|
|
* "addresses": <List<Address>> // List of Address objects, one for each participant of the conversation
|
|
|
|
* // The user's Address is excluded so:
|
2019-12-22 08:15:58 +00:00
|
|
|
* // If this is a single-target message, there will only be one
|
2019-07-20 21:35:53 +01:00
|
|
|
* // Address (the other party)
|
|
|
|
* // If this is an incoming multi-target message, the first Address is the
|
|
|
|
* // sender and all other addresses are other parties to the conversation
|
|
|
|
* // If this is an outgoing multi-target message, the sender is implicit
|
|
|
|
* // (the user's phone number) and all Addresses are recipients
|
2018-11-15 23:57:58 +00:00
|
|
|
* "date" : "1518846484880", // Timestamp of the message
|
|
|
|
* "type" : "2", // Compare with Android's
|
|
|
|
* // Telephony.TextBasedSmsColumns.MESSAGE_TYPE_*
|
2019-07-20 21:35:53 +01:00
|
|
|
* "thread_id" : 132 // Thread to which the message belongs
|
2018-11-15 23:57:58 +00:00
|
|
|
* "read" : true // Boolean representing whether a message is read or unread
|
|
|
|
* },
|
|
|
|
* { ... },
|
|
|
|
* ...
|
|
|
|
* ]
|
2019-07-20 21:35:53 +01:00
|
|
|
*
|
|
|
|
* The following optional fields of a message object may be defined
|
|
|
|
* "sub_id": <int> // Android's subscriber ID, which is basically used to determine which SIM card the message
|
|
|
|
* // belongs to. This is mostly useful when attempting to reply to an SMS with the correct
|
|
|
|
* // SIM card using PACKET_TYPE_SMS_REQUEST.
|
|
|
|
* // If this value is not defined or if it does not match a valid subscriber_id known by
|
|
|
|
* // Android, we will use whatever subscriber ID Android gives us as the default
|
|
|
|
*
|
|
|
|
* An Address object looks like:
|
|
|
|
* {
|
|
|
|
* "address": <String> // Address (phone number, email address, etc.) of this object
|
|
|
|
* }
|
2018-09-10 10:28:54 +01:00
|
|
|
*/
|
2018-09-16 23:03:31 +01:00
|
|
|
#define PACKET_TYPE_SMS_MESSAGES QStringLiteral("kdeconnect.sms.messages")
|
2018-09-10 10:28:54 +01:00
|
|
|
|
2018-09-16 23:03:31 +01:00
|
|
|
/**
|
|
|
|
* Packet sent to request a message be sent
|
|
|
|
*
|
|
|
|
* This will almost certainly need to be replaced or augmented to support MMS,
|
|
|
|
* but be sure the Android side remains compatible with old desktop apps!
|
|
|
|
*
|
|
|
|
* The body should look like so:
|
|
|
|
* { "sendSms": true,
|
2020-07-08 09:16:56 +01:00
|
|
|
* "addresses": <List of Addresses>
|
2020-03-20 02:16:55 +00:00
|
|
|
* "messageBody": "Hi mom!",
|
|
|
|
* "sub_id": "3859358340534"
|
2018-09-16 23:03:31 +01:00
|
|
|
* }
|
|
|
|
*/
|
2018-09-10 10:28:54 +01:00
|
|
|
#define PACKET_TYPE_SMS_REQUEST QStringLiteral("kdeconnect.sms.request")
|
|
|
|
|
|
|
|
/**
|
2018-09-16 23:03:31 +01:00
|
|
|
* Packet sent to request the most-recent message in each conversations on the device
|
2018-09-10 10:28:54 +01:00
|
|
|
*
|
|
|
|
* The request packet shall contain no body
|
|
|
|
*/
|
2018-09-16 23:03:31 +01:00
|
|
|
#define PACKET_TYPE_SMS_REQUEST_CONVERSATIONS QStringLiteral("kdeconnect.sms.request_conversations")
|
2018-09-10 10:28:54 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Packet sent to request all the messages in a particular conversation
|
|
|
|
*
|
2018-09-16 23:03:31 +01:00
|
|
|
* The body should contain the key "threadID" mapping to the threadID being requested
|
2018-09-10 10:28:54 +01:00
|
|
|
* For example:
|
|
|
|
* { "threadID": 203 }
|
|
|
|
*/
|
2018-09-16 23:03:31 +01:00
|
|
|
#define PACKET_TYPE_SMS_REQUEST_CONVERSATION QStringLiteral("kdeconnect.sms.request_conversation")
|
2018-09-10 10:28:54 +01:00
|
|
|
|
|
|
|
Q_DECLARE_LOGGING_CATEGORY(KDECONNECT_PLUGIN_SMS)
|
|
|
|
|
|
|
|
class Q_DECL_EXPORT SmsPlugin
|
|
|
|
: public KdeConnectPlugin
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
Q_CLASSINFO("D-Bus Interface", "org.kde.kdeconnect.device.sms")
|
|
|
|
|
|
|
|
public:
|
|
|
|
explicit SmsPlugin(QObject* parent, const QVariantList& args);
|
|
|
|
~SmsPlugin() override;
|
|
|
|
|
|
|
|
bool receivePacket(const NetworkPacket& np) override;
|
|
|
|
void connected() override {}
|
|
|
|
|
|
|
|
QString dbusPath() const override;
|
|
|
|
|
|
|
|
public Q_SLOTS:
|
2020-07-08 09:16:56 +01:00
|
|
|
Q_SCRIPTABLE void sendSms(const QDBusVariant& addresses, const QString& messageBody, const qint64 subID = -1);
|
2018-09-10 10:28:54 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Send a request to the remote for all of its conversations
|
|
|
|
*/
|
|
|
|
Q_SCRIPTABLE void requestAllConversations();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Send a request to the remote for a particular conversation
|
[SMS App] Make requestMoreMessages asynchronous, blocking, and caching
Summary:
The most serious change from this patch is to move the asynchronous replying to a request from the app for more messages to a newly-spawned, self-destructing thread. Within that thread, we block until the remote device replies with the requested messages.
All gotten messages are cached in the ConversationDbusInterface, so all future requests are fast and don't hit the remote device.
Test Plan: After applying this diff, the messaging app should show 10 messages every time it is opened
Reviewers: #kde_connect, nicolasfella, albertvaka
Reviewed By: #kde_connect, albertvaka
Subscribers: albertvaka, apol, nicolasfella, kdeconnect
Tags: #kde_connect
Differential Revision: https://phabricator.kde.org/D16475
2018-12-13 05:42:45 +00:00
|
|
|
*
|
|
|
|
* TODO: Make interface capable of requesting limited window of messages
|
2018-09-10 10:28:54 +01:00
|
|
|
*/
|
[SMS App] Make requestMoreMessages asynchronous, blocking, and caching
Summary:
The most serious change from this patch is to move the asynchronous replying to a request from the app for more messages to a newly-spawned, self-destructing thread. Within that thread, we block until the remote device replies with the requested messages.
All gotten messages are cached in the ConversationDbusInterface, so all future requests are fast and don't hit the remote device.
Test Plan: After applying this diff, the messaging app should show 10 messages every time it is opened
Reviewers: #kde_connect, nicolasfella, albertvaka
Reviewed By: #kde_connect, albertvaka
Subscribers: albertvaka, apol, nicolasfella, kdeconnect
Tags: #kde_connect
Differential Revision: https://phabricator.kde.org/D16475
2018-12-13 05:42:45 +00:00
|
|
|
Q_SCRIPTABLE void requestConversation(const qint64& conversationID) const;
|
2018-09-10 10:28:54 +01:00
|
|
|
|
2019-07-20 15:02:38 +01:00
|
|
|
Q_SCRIPTABLE void launchApp();
|
|
|
|
|
2018-09-10 10:28:54 +01:00
|
|
|
private:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Send to the telepathy plugin if it is available
|
|
|
|
*/
|
|
|
|
void forwardToTelepathy(const ConversationMessage& message);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handle a packet which contains many messages, such as PACKET_TYPE_TELEPHONY_MESSAGE
|
|
|
|
*/
|
|
|
|
bool handleBatchMessages(const NetworkPacket& np);
|
|
|
|
|
|
|
|
QDBusInterface m_telepathyInterface;
|
|
|
|
ConversationsDbusInterface* m_conversationInterface;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|