summaryrefslogtreecommitdiff
path: root/Program.cs
blob: 5f8de30cd88e7fd36ed045b9f053312b4d862bc8 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
using System;
using System.Net;
using System.Net.Sockets;

const char DELIM = ' ';
const int DELAY_DURATION_S = 990;

short ReadPort() => args.Length != 0 && short.TryParse(args[0], out var port) ? port : (short)22;

IList<string> ReadBanner() => Console.In.ReadToEnd().Split(DELIM, StringSplitOptions.RemoveEmptyEntries);

async Task SshClientHandler(TcpClient client, IEnumerable<string> banner)
{
    var remote = client.Client.RemoteEndPoint;
    Console.WriteLine($"{remote}: Client connected.");

    try
    {
        using (client)
        {
            var stream = client.GetStream();
            var writer = new StreamWriter(stream) { AutoFlush = true };

            while (true)
            {
                foreach (var word in banner)
                {
                    await writer.WriteAsync($"{word}{DELIM}");
                    await Task.Delay(DELAY_DURATION_S);
                }

                Console.WriteLine($"{remote}: Client read it all!");
            }
        }
    }
    catch (Exception ex)
    {
        Console.WriteLine($"{remote}: Client handler error: {ex.Message}");
    }
    finally
    {
        Console.WriteLine($"{remote}: Client hung up");
    }
}

// main 
var banner = ReadBanner();
var port = ReadPort();
var listener = new TcpListener(IPAddress.Any, port);

using (listener)
{
    listener.Start();
    Console.WriteLine($"Listening on port {port}...");

    while (true)
    {
        try
        {
            var client = await listener.AcceptTcpClientAsync();

            _ = Task.Run(() => SshClientHandler(client, banner));
        }
        catch (Exception ex)
        {
            Console.WriteLine($"Accept error: {ex.Message}");
        }
    }
}