// SPDX-FileCopyrightText: 2018 Kitsune Ral // SPDX-License-Identifier: LGPL-2.1-or-later #pragma once #include "stateevent.h" namespace Quotient { namespace _impl { template static inline auto loadEvent(const QJsonObject& json, const QString& matrixType) { if (auto e = EventFactory::make(json, matrixType)) return e; return makeEvent(unknownEventTypeId(), json); } } // namespace _impl /*! Create an event with proper type from a JSON object * * Use this factory template to detect the type from the JSON object * contents (the detected event type should derive from the template * parameter type) and create an event object of that type. */ template inline event_ptr_tt loadEvent(const QJsonObject& fullJson) { return _impl::loadEvent(fullJson, fullJson[TypeKeyL].toString()); } /*! Create an event from a type string and content JSON * * Use this factory template to resolve the C++ type from the Matrix * type string in \p matrixType and create an event of that type that has * its content part set to \p content. */ template inline event_ptr_tt loadEvent(const QString& matrixType, const QJsonObject& content) { return _impl::loadEvent(basicEventJson(matrixType, content), matrixType); } /*! Create a state event from a type string, content JSON and state key * * Use this factory to resolve the C++ type from the Matrix type string * in \p matrixType and create a state event of that type with content part * set to \p content and state key set to \p stateKey (empty by default). */ inline StateEventPtr loadStateEvent(const QString& matrixType, const QJsonObject& content, const QString& stateKey = {}) { return _impl::loadEvent( basicStateEventJson(matrixType, content, stateKey), matrixType); } template struct JsonConverter> { static auto load(const QJsonValue& jv) { return loadEvent(jv.toObject()); } static auto load(const QJsonDocument& jd) { return loadEvent(jd.object()); } }; } // namespace Quotient