프로젝트

일반

사용자정보

통계
| 브랜치(Branch): | 개정판:

markus / MarkusLogview / MarkusConsoleApplication / Program.cs @ d3161976

이력 | 보기 | 이력해설 | 다운로드 (7.47 KB)

1 84578b97 djkim
using MarkusDataModel.Common;
2
using MarkusDataModel.DataModel;
3
using Microsoft.AspNet.SignalR.Client;
4
using ServiceInterface;
5
using System;
6
using System.Collections;
7
using System.Collections.Generic;
8
using System.Data;
9
using System.Diagnostics;
10
using System.Linq;
11
using System.Reflection;
12
using System.Text;
13
using System.Threading.Tasks;
14
using TableDependency;
15
using TableDependency.EventArgs;
16
using TableDependency.SqlClient;
17
using static MarkusConsoleApplication.HubConfiguration;
18
19
namespace MarkusConsoleApplication
20
{
21
    class Program
22
    {
23
        private static SqlTableDependency<CONVERTER_DOC> _convertTableDependency;
24
        private static SqlTableDependency<FINAL_PDF> _finalTableDependency;
25
        private static string entityConnString = ConnectStringBuilder.MarkusEntitiesConnectionString().ProviderConnectionString.ToString();
26
        private static ServiceEventLogger _serviceEventLogger = new ServiceEventLogger();
27
28
        private static string hubBaseURL = "http://cloud.devdoftech.co.kr:5100";
29
        private static string hubName = "MarkusHub";
30
        private static ConvertSetting convSetting = new ConvertSetting();
31
        private static FinalSetting finalSetting = new FinalSetting();
32
        private static DetectedType detectedType = new DetectedType();
33
34
35
        static void Main(string[] args)
36
        {
37
            #region 메인
38
39
            // convert
40
            try
41
            {
42
                // config
43
                var convertMapper = new ModelToTableMapper<CONVERTER_DOC>();
44
                convertMapper.AddMapping(s => s.CURRENT_PAGE, "CURRENT_PAGE");
45
                _convertTableDependency = new SqlTableDependency<CONVERTER_DOC>(entityConnString, "CONVERTER_DOC", convertMapper);
46
47
                // add event 
48
                _convertTableDependency.OnError += SqlTableDependency_OnError;
49
                _convertTableDependency.OnChanged += Convert_SqlTableDependency_Changed;
50
                _convertTableDependency.Start();
51
52
                // log 
53
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name + " start", EventLogEntryType.SuccessAudit);
54
55
            }
56
            catch (Exception ex)
57
            {
58
                _serviceEventLogger.WriteEventEntry("SQL Dependency ERROR " + MethodBase.GetCurrentMethod().Name + " : " + ex.Message, EventLogEntryType.Error);
59
                throw;
60
            }
61
62
            // final
63
            try
64
            {
65
                var finalMapper = new ModelToTableMapper<FINAL_PDF>();
66
                finalMapper.AddMapping(s => s.CURRENT_PAGE, "CURRENT_PAGE");
67
68
                _finalTableDependency = new SqlTableDependency<FINAL_PDF>(entityConnString, "FINAL_PDF", finalMapper);
69
70
                _finalTableDependency.OnError += SqlTableDependency_OnError;
71
                _finalTableDependency.OnChanged += Final_SqlTableDependency_Changed;
72
73
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name + " start", EventLogEntryType.SuccessAudit);
74
75
                _finalTableDependency.Start();
76
77
            }
78
            catch (Exception ex)
79
            {
80
                _serviceEventLogger.WriteEventEntry("SQL Dependency ERROR " + MethodBase.GetCurrentMethod().Name + " : " + ex.Message, EventLogEntryType.Error);
81
82
                throw;
83
            }
84
85
            Console.ReadKey();
86
87
            #endregion
88
        }
89
90
        /// <summary>
91
        /// SQL Dependency Error code 
92
        /// </summary>
93
        /// <param name="sender"></param>
94
        /// <param name="e"></param>
95
        public static void SqlTableDependency_OnError(object sender, ErrorEventArgs e)
96
        {
97
            _serviceEventLogger.WriteEventEntry(" SQL Dependency ERROR " + MethodBase.GetCurrentMethod().Name + " :: " + e.Message, EventLogEntryType.Error);
98
            throw e.Error;
99
        }
100
101
102
        /// <summary>
103
        /// Converter Sql Dependency Changed
104
        /// </summary>
105
        /// <param name="sender"></param>
106
        /// <param name="e"></param>
107
        public static void Convert_SqlTableDependency_Changed(object sender, RecordChangedEventArgs<CONVERTER_DOC> e)
108
        {
109
            try
110
            {
111
112
                string changeType = e.ChangeType.ToString();
113
                DetectedMakrusConvertTable(e.ChangeType.ToString(), e.Entity);
114
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name + " changeType : " + changeType, EventLogEntryType.SuccessAudit);
115
116
            }
117
            catch (Exception ex)
118
            {
119
                _serviceEventLogger.WriteEventEntry("Convert_SqlTableDependency_Changed Error : " + ex, EventLogEntryType.Error);
120
                throw;
121
            }
122
        }
123
124
        /// <summary>
125
        /// Final Sql Dependency Changed 
126
        /// </summary>
127
        /// <param name="sender"></param>
128
        /// <param name="e"></param>
129
        public static void Final_SqlTableDependency_Changed(object sender, RecordChangedEventArgs<FINAL_PDF> e)
130
        {
131
            try
132
            {
133
                string changeType = e.ChangeType.ToString();
134
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name + " changeType : " + changeType, EventLogEntryType.SuccessAudit);
135
136
                DetectedMakrusFinalTable(changeType, e.Entity);
137
138
            }
139
            catch (Exception ex)
140
            {
141
                _serviceEventLogger.WriteEventEntry("Final_SqlTableDependency_Changed Error : " + ex, EventLogEntryType.Error);
142
                throw;
143
            }
144
        }
145
146
        /// <summary>
147
        /// Convert Hub Send
148
        /// </summary>
149
        /// <param name="type"></param>
150
        /// <param name="data"></param>
151
        public static void DetectedMakrusConvertTable(string type, CONVERTER_DOC data)
152
        {
153
154
            using (var hubConn = new HubConnection(hubBaseURL))
155
            {
156
157
                var hub = hubConn.CreateHubProxy(hubName);
158
159
                hubConn.Start().Wait();
160
161
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name, EventLogEntryType.SuccessAudit);
162
163
                if (type == detectedType.DataInsert)
164
                {
165
                    hub.Invoke(convSetting.InvokeInsert, data);
166
                }
167
                else if (type == detectedType.DataUpdate)
168
                {
169
                    hub.Invoke(convSetting.InvokeChange, data);
170
                }
171
                else if (type == detectedType.DataDelete)
172
                {
173
                    hub.Invoke(convSetting.InvokeDelete, data);
174
                }
175
176
            }
177
178
        }
179
180
        /// <summary>
181
        /// Final Hub Send
182
        /// </summary>
183
        /// <param name="type"></param>
184
        /// <param name="data"></param>
185
        public static void DetectedMakrusFinalTable(string type, FINAL_PDF data)
186
        {
187
188
            using (var hubConn = new HubConnection(hubBaseURL))
189
            {
190
191
                var hub = hubConn.CreateHubProxy(hubName);
192
193
                hubConn.Start().Wait();
194
195
                _serviceEventLogger.WriteEventEntry(MethodBase.GetCurrentMethod().Name, EventLogEntryType.SuccessAudit);
196
197
                if (type == detectedType.DataInsert)
198
                {
199
                    hub.Invoke(finalSetting.InvokeInsert, data);
200
                }
201
                else if (type == detectedType.DataUpdate)
202
                {
203
                    hub.Invoke(finalSetting.InvokeChange, data);
204
                }
205
                else if (type == detectedType.DataDelete)
206
                {
207
                    hub.Invoke(finalSetting.InvokeDelete, data);
208
                }
209
210
            }
211
212
        }
213
214
215
    }
216
}
클립보드 이미지 추가 (최대 크기: 500 MB)