blob: 19752a6b8d38766cb976ff0a5f90747bfd3e6dc4 (
plain)
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
70
71
72
73
74
75
|
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Azure.Management.AppService.Fluent;
using Microsoft.Azure.Management.Fluent;
namespace Tango.AzureUtils.Logging
{
public class LogStreamManager : AzureUtilsComponentBase
{
private Stream _currentStream;
private StreamReader _reader;
private Thread _pullThread;
public event EventHandler<String> LogAvailable;
public LogStreamManager(IAzure azure) : base(azure)
{
}
public void StopLogStreaming()
{
_reader.Dispose();
_currentStream.Dispose();
_reader = null;
_currentStream = null;
_pullThread = null;
}
public async Task StartLogStreamingAsync(IWebAppBase webApp)
{
_currentStream = await webApp.StreamApplicationLogsAsync();
_reader = new StreamReader(_currentStream);
if (_pullThread == null)
{
_pullThread = new Thread(PullThreadMethod);
_pullThread.IsBackground = true;
_pullThread.Start();
}
}
private void PullThreadMethod()
{
while (_currentStream != null)
{
String line = null;
do
{
try
{
line = _reader.ReadLine();
if (line != null)
{
LogAvailable?.Invoke(this, line);
}
}
catch
{
line = null;
}
} while (line != null);
Thread.Sleep(2000);
}
}
}
}
|