public void AddToCluster(string clusterTag, string url)
        {
            var clusterNode = new ClusterNode(clusterTag, url, _term, _contextPool, this, _cts.Token);

            _clusterNodes[clusterTag] = clusterNode;
            clusterNode.Start();
        }
Exemple #2
0
        private static void InitializeNode()
        {
            while (localPort < 1 || remotePort < 1)
            {
                Console.Write("Local port  : ");
                localPort = Convert.ToInt32(Console.ReadLine());
                Console.Write("Remote port : ");
                remotePort = Convert.ToInt32(Console.ReadLine());
            }

            node = new ClusterNode("127.0.0.1", localPort, "127.0.0.1", remotePort, null, null);
            node.AcceptInvalidCertificates = true;
            node.MutuallyAuthenticate      = false;
            node.PresharedKey = "0000000000000000";

            node.MessageReceived  += MessageReceived;
            node.ClusterHealthy   += ClusterHealthy;
            node.ClusterUnhealthy += ClusterUnhealthy;
            node.Logger            = Logger;
            node.Start();
        }
Exemple #3
0
        static void Main(string[] args)
        {
            while (localPort < 1 || remotePort < 1)
            {
                Console.Write("Local port  : ");
                localPort = Convert.ToInt32(Console.ReadLine());
                Console.Write("Remote port : ");
                remotePort = Convert.ToInt32(Console.ReadLine());
            }

            n = new ClusterNode("127.0.0.1", localPort, "127.0.0.1", remotePort, null, null);
            n.AcceptInvalidCertificates = true;
            n.MutuallyAuthenticate      = true;
            n.Debug            = false;
            n.ReadDataStream   = false;
            n.PresharedKey     = "0000000000000000";
            n.MessageReceived  = MessageReceived;
            n.StreamReceived   = StreamReceived;
            n.ClusterHealthy   = ClusterHealthy;
            n.ClusterUnhealthy = ClusterUnhealthy;

            n.Start();

            bool runForever = true;

            while (runForever)
            {
                Console.Write("Command [? for help]: ");
                string userInput = Console.ReadLine();
                if (String.IsNullOrEmpty(userInput))
                {
                    continue;
                }

                byte[]       data = null;
                MemoryStream ms   = null;

                switch (userInput)
                {
                case "?":
                    Console.WriteLine("---");
                    Console.WriteLine(" q                   quit");
                    Console.WriteLine(" ?                   this menu");
                    Console.WriteLine(" cls                 clear screen");
                    Console.WriteLine(" send bytes          send message to peer");
                    Console.WriteLine(" send bytes async    send message to peer, asynchronously");
                    Console.WriteLine(" send stream         send message to peer using a stream");
                    Console.WriteLine(" send stream async   send message to peer using a stream, asynchronously");
                    Console.WriteLine(" health              display cluster health");
                    break;

                case "q":
                    runForever = false;
                    break;

                case "cls":
                    Console.Clear();
                    break;

                case "send bytes":
                    Console.Write("Data: ");
                    userInput = Console.ReadLine();
                    if (n.Send(Encoding.UTF8.GetBytes(userInput)))
                    {
                        Console.WriteLine("Success");
                    }
                    else
                    {
                        Console.WriteLine("Failed");
                    }
                    break;

                case "send bytes async":
                    Console.Write("Data: ");
                    userInput = Console.ReadLine();
                    if (n.SendAsync(Encoding.UTF8.GetBytes(userInput)).Result)
                    {
                        Console.WriteLine("Success");
                    }
                    else
                    {
                        Console.WriteLine("Failed");
                    }
                    break;

                case "send stream":
                    Console.Write("Data: ");
                    userInput = Console.ReadLine();
                    data      = Encoding.UTF8.GetBytes(userInput);
                    ms        = new MemoryStream(data);
                    if (n.Send(data.Length, ms))
                    {
                        Console.WriteLine("Success");
                    }
                    else
                    {
                        Console.WriteLine("Failed");
                    }
                    break;

                case "send stream async":
                    Console.Write("Data: ");
                    userInput = Console.ReadLine();
                    data      = Encoding.UTF8.GetBytes(userInput);
                    ms        = new MemoryStream(data);
                    if (n.SendAsync(data.Length, ms).Result)
                    {
                        Console.WriteLine("Success");
                    }
                    else
                    {
                        Console.WriteLine("Failed");
                    }
                    break;

                case "health":
                    Console.WriteLine("Healthy: " + n.IsHealthy);
                    break;
                }
            }
        }