1 /***************************************************************************
2 * Copyright (C) 2005-2018 by the Quassel Project *
3 * devel@quassel-irc.org *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) version 3. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 * You should have received a copy of the GNU General Public License *
16 * along with this program; if not, write to the *
17 * Free Software Foundation, Inc., *
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
19 ***************************************************************************/
21 #include "ctcpevent.h"
23 #include "networkevent.h"
24 #include "messageevent.h"
26 #include "signalproxy.h"
28 Event::Event(EventManager::EventType type)
35 Event::Event(EventManager::EventType type, QVariantMap &map)
39 if (!map.contains("flags") || !map.contains("timestamp")) {
40 qWarning() << "Received invalid serialized event:" << map;
45 Q_ASSERT(SignalProxy::current());
46 Q_ASSERT(SignalProxy::current()->sourcePeer());
48 setFlags(static_cast<EventManager::EventFlags>(map.take("flags").toInt())); // TODO sanity check?
50 if (SignalProxy::current()->sourcePeer()->hasFeature(Quassel::Feature::LongTime)) {
51 // timestamp is a qint64, signed rather than unsigned
52 setTimestamp(QDateTime::fromMSecsSinceEpoch(map.take("timestamp").toLongLong()));
54 setTimestamp(QDateTime::fromTime_t(map.take("timestamp").toUInt()));
59 void Event::toVariantMap(QVariantMap &map) const
61 Q_ASSERT(SignalProxy::current());
62 Q_ASSERT(SignalProxy::current()->targetPeer());
64 map["type"] = static_cast<int>(type());
65 map["flags"] = static_cast<int>(flags());
66 if (SignalProxy::current()->targetPeer()->hasFeature(Quassel::Feature::LongTime)) {
67 // toMSecs returns a qint64, signed rather than unsigned
68 map["timestamp"] = timestamp().toMSecsSinceEpoch();
70 map["timestamp"] = timestamp().toTime_t();
75 QVariantMap Event::toVariantMap() const
83 Event *Event::fromVariantMap(QVariantMap &map, Network *network)
85 int inttype = map.take("type").toInt();
86 // sanity check if we have a valid enum value
87 if (EventManager::enumName(inttype).isEmpty()) {
88 qWarning() << "Received a serialized event with unknown type" << inttype;
92 EventManager::EventType type = static_cast<EventManager::EventType>(inttype);
93 if (type == EventManager::Invalid || type == EventManager::GenericEvent)
96 EventManager::EventType group = static_cast<EventManager::EventType>(type & EventManager::EventGroupMask);
100 // we use static create() functions to keep group-specific special cases in the files they belong
101 // e.g. IrcEventRawMessage
103 case EventManager::NetworkEvent:
104 e = NetworkEvent::create(type, map, network);
106 case EventManager::IrcServerEvent:
109 case EventManager::IrcEvent:
110 e = IrcEvent::create(type, map, network);
112 case EventManager::MessageEvent:
113 e = MessageEvent::create(type, map, network);
115 case EventManager::CtcpEvent:
116 e = CtcpEvent::create(type, map, network);
123 qWarning() << "Can't create event of type" << type;
127 if (!map.isEmpty()) {
128 qWarning() << "Event creation from map did not consume all data:" << map;
135 QDebug operator<<(QDebug dbg, Event *e)
137 dbg.nospace() << qPrintable(e->className()) << "("
138 << "type = 0x" << qPrintable(QString::number(e->type(), 16));
140 //<< ", data = " << e->data(); // we don't use data anywhere yet
141 dbg.nospace() << ", flags = 0x" << qPrintable(QString::number(e->flags(), 16))