import 'package:cli_repl/cli_repl.dart'; import 'package:example_dart/arguments.dart'; import 'package:example_dart/socket.dart'; import 'package:logging/logging.dart'; import 'package:moxxmpp/moxxmpp.dart'; void main(List args) async { // Set up logging Logger.root.level = Level.ALL; Logger.root.onRecord.listen((record) { // ignore: avoid_print print( '[${record.level.name}] (${record.loggerName}) ${record.time}: ${record.message}', ); }); final parser = ArgumentParser() ..parser.addOption('muc', help: 'The MUC to send messages to') ..parser.addOption('nick', help: 'The nickname with which to join the MUC'); final options = parser.handleArguments(args); if (options == null) { return; } // Connect final muc = JID.fromString(options['muc']! as String).toBare(); final nick = options['nick']! as String; final connection = XmppConnection( TestingReconnectionPolicy(), AlwaysConnectedConnectivityManager(), ClientToServerNegotiator(), ExampleTCPSocketWrapper(parser.srvRecord), )..connectionSettings = parser.connectionSettings; // Register the managers and negotiators await connection.registerManagers([ PresenceManager(), DiscoManager([]), PubSubManager(), MessageManager(), MUCManager(), ]); await connection.registerFeatureNegotiators([ SaslPlainNegotiator(), ResourceBindingNegotiator(), StartTlsNegotiator(), SaslScramNegotiator(10, '', '', ScramHashType.sha1), ]); // Connect Logger.root.info('Connecting...'); final result = await connection.connect(shouldReconnect: false, waitUntilLogin: true); if (!result.isType()) { Logger.root.severe('Authentication failed!'); return; } Logger.root.info('Connected.'); // Join room await connection.getManagerById(mucManager)!.joinRoom(muc, nick); final repl = Repl(prompt: '> '); await for (final line in repl.runAsync()) { await connection .getManagerById(messageManager)! .sendMessage( muc, TypedMap.fromList([ MessageBodyData(line), ]), type: 'groupchat'); } // Leave room await connection.getManagerById(mucManager)!.leaveRoom(muc); // Disconnect await connection.disconnect(); }