Line data Source code
1 : /* 2 : * Copyright (C) 2004-2024 Savoir-faire Linux Inc. 3 : * 4 : * This program is free software: you can redistribute it and/or modify 5 : * it under the terms of the GNU General Public License as published by 6 : * the Free Software Foundation, either version 3 of the License, or 7 : * (at your option) any later version. 8 : * 9 : * This program is distributed in the hope that it will be useful, 10 : * but WITHOUT ANY WARRANTY; without even the implied warranty of 11 : * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 : * GNU General Public License for more details. 13 : * 14 : * You should have received a copy of the GNU General Public License 15 : * along with this program. If not, see <https://www.gnu.org/licenses/>. 16 : */ 17 : #pragma once 18 : 19 : #include "jamidht/channel_handler.h" 20 : #include "jamidht/jamiaccount.h" 21 : #include <dhtnet/connectionmanager.h> 22 : 23 : namespace jami { 24 : 25 : /** 26 : * Manages channels for exchanging messages between peers 27 : */ 28 : class MessageChannelHandler : public ChannelHandlerInterface 29 : { 30 : public: 31 : MessageChannelHandler(const std::shared_ptr<JamiAccount>& acc, dhtnet::ConnectionManager& cm); 32 : ~MessageChannelHandler(); 33 : 34 : /** 35 : * Ask for a new message channel 36 : * @param deviceId The device to connect 37 : * @param name (Unused, generated from deviceId) 38 : * @param cb The callback to call when connected (can be immediate if already connected) 39 : * @param connectionType for iOS notifications 40 : * @param forceNewConnection If we want a new SIP connection 41 : */ 42 : void connect(const DeviceId& deviceId, 43 : const std::string&, 44 : ConnectCb&& cb, 45 : const std::string& connectionType, 46 : bool forceNewConnection = false) override; 47 : 48 : std::shared_ptr<dhtnet::ChannelSocket> getChannel(const std::string& peer, 49 : const DeviceId& deviceId) const; 50 : std::vector<std::shared_ptr<dhtnet::ChannelSocket>> getChannels(const std::string& peer) const; 51 : 52 : /** 53 : * Determine if we accept or not the message request 54 : * @param deviceId Device who asked 55 : * @param name Name asked 56 : * @return if the channel is for a valid conversation and device not banned 57 : */ 58 : bool onRequest(const std::shared_ptr<dht::crypto::Certificate>& peer, 59 : const std::string& name) override; 60 : 61 : /** 62 : * Launch message process 63 : * @param deviceId Device who asked 64 : * @param name Name asked 65 : * @param channel Channel used to message 66 : */ 67 : void onReady(const std::shared_ptr<dht::crypto::Certificate>& peer, 68 : const std::string& name, 69 : std::shared_ptr<dhtnet::ChannelSocket> channel) override; 70 : 71 : struct Message 72 : { 73 : std::string t; /* Message type */ 74 : std::string c; /* Message content */ 75 : std::unique_ptr<ConversationRequest> req; /* Conversation request */ 76 31492 : MSGPACK_DEFINE_MAP(t, c, req) 77 : }; 78 : 79 : static bool sendMessage(const std::shared_ptr<dhtnet::ChannelSocket>&, const Message& message); 80 : 81 : private: 82 : struct Impl; 83 : std::shared_ptr<Impl> pimpl_; 84 : }; 85 : 86 : } // namespace jami