/** This file is a part of r0nk, atlas_moon, and rexy's matrix client Copyright (C) 2019 rexy712 This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. 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 Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . */ //Example of a bot which accepts any invite that it is given #include "matrix/matrix.hpp" int main(){ //auth information needed to initiate a session const char* username = "username"; const char* password = "password"; const char* useragent = "rexy712s invite accepter"; const char* homeserver = "matrix.org"; matrix::auth_data auth{username, password, homeserver, useragent}; //create on open connection to the homeserver matrix::session ses(auth); //access syncer instance to pull from server matrix::syncer& syn = ses.get_syncer(); //access client instance to accept invites matrix::client& client = ses.get_client(); //initial sync to clear backlog auto sync_reply = syn.sync(0); //callback on recieved membership events (invite, join, leave, ban, etc) //uses ref capture lambda to access client instance for invite acceptance syn.set_membership_callback([&](const matrix::membership_info& invite)->void{ client.accept_invite(invite); }); //continuously loop syncing operation to always keep up to date with the server state while(1){ sync_reply = syn.sync(30000); } }