프로젝트

일반

사용자정보

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

markus / ConvertService / ServiceBase / ConvertionWebService / Conversion.asmx.cs @ 3dc74093

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

1
using System;
2
using System.Collections.Generic;
3
using System.Linq;
4
using System.Web;
5
using System.Web.Services;
6
using System.Runtime.Remoting.Channels;
7
using System.Runtime.Remoting.Channels.Tcp;
8
using IConverterPDF;
9
using System.Text;
10
using DeepViewDataModel.DataModel;
11
using DeepViewDataModel.Common;
12
using DeepView.Toolkit.GuidGenerator;
13
using MarkupToPDF;
14
using System.IO;
15
using Newtonsoft.Json;
16
using Newtonsoft.Json.Linq;
17
using log4net;
18

    
19
namespace ConvertionWebService
20
{
21
    /// <summary>
22
    /// Summary description for Conversio
23
    /// </summary>
24
    [WebService(Namespace = "http://tempuri.org/")]
25
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
26
    [System.ComponentModel.ToolboxItem(false)]
27
    public class Conversion : System.Web.Services.WebService
28
    {
29

    
30
        RemConverterPDFObject remObj = null;
31
        protected ILog logger = LogManager.GetLogger(typeof(Conversion));
32
        public Conversion()
33
        {
34
            try
35
            {
36
                System.Runtime.Remoting.Channels.IChannel _ch = ChannelServices.GetChannel("tcp");
37

    
38
                if(_ch == null)
39
                {
40
                    TcpChannel chan = new TcpChannel();
41
                    ChannelServices.RegisterChannel(chan, false);
42
                }
43
                // Create an instance of the remote object
44
                remObj = (RemConverterPDFObject)Activator.GetObject(typeof(RemConverterPDFObject),
45
                                                            Properties.Settings.Default.ConverterRemotingUrl);
46

    
47
            }
48
            catch (Exception ex)
49
            {
50
                logger.Error("Conversion Web Service Conversion Error", ex);
51
                SendNotice(ex.ToString());
52
            }
53
        }
54

    
55
        private void SendNotice(string ex)
56
        {
57
            if (!string.IsNullOrWhiteSpace(Properties.Settings.Default.ErrorNoticeID))
58
            {
59
                var _lstID = Properties.Settings.Default.ErrorNoticeID.Split(';').ToList();
60
                //EmailClient.EmailClient _client = new EmailClient.EmailClient(_lstID.First());
61
                StringBuilder _bl = new StringBuilder();
62
                _bl.AppendLine("Conversion Web Service Error");
63
                _bl.AppendLine(ex);
64
                //var _emailResult = _client.SendEmail(_lstID, _lstID, "<Conversion Web Service Error>", _bl.ToString(), false);
65
            }
66
            else
67
            {
68
                logger.Error("Conversion Web Service Error",new Exception(ex));
69
            }
70
        }
71

    
72
        [WebMethod]
73
        public string ConvertRun(string rev_No, string document_No, string document_Name, string group_No, string prj_No, string document_Id, string document_Url)
74
        {
75
            string _result = null;
76
            try
77
            {
78
                logger.Info($"Conversion Web Service ConvertRun call rev_No :{rev_No} document_No : {document_No}  document_Name : {document_Name}  group_No : {group_No}  prj_No : {prj_No}  document_Id : {document_Id}  document_Url : {document_Url}");
79

    
80
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
81
                {
82
                    //_result = ConnectStringBuilder.DeepViewConnectionString().ToString();
83
                    //var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO == projNumber && DateTime.Parse(r.RUN_DATETIME)<= DateTime.Now);
84
                    //var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO == projNumber);
85
                    var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO != null);
86

    
87
                    if (_RunProjects.Count() > 0)
88
                    {
89
                        _result = SendKcom(rev_No, document_No, document_Name, group_No, prj_No, document_Id, document_Url);
90
                    }
91
                    else
92
                    {
93
                        _result = false.ToString();
94
                    }
95
                }
96
            }
97
            catch (Exception ex)
98
            {
99
                logger.Error($"Conversion Web Service ConvertRun Error rev_No :{rev_No} document_No : {document_No}  document_Name : {document_Name}  group_No : {group_No}  prj_No : {prj_No}  document_Id : {document_Id}  document_Url : {document_Url}", ex);
100
                _result = ex.Message.ToString();
101
                SendNotice("Project NO : " + prj_No + "\r\n  DocumentUrl : " + document_Url + "\r\n Error" + ex.ToString());
102
            }
103
            return _result;
104
        }
105

    
106
        [WebMethod]
107
        public string ConvertRunIgnoreComment(string rev_No, string document_No, string document_Name, string group_No, string prj_No, string document_Id, string document_Url, string ignoreComment)
108
        {
109
            string _result = null;
110
            try
111
            {
112
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
113
                {
114
                    //_result = ConnectStringBuilder.DeepViewConnectionString().ToString();
115
                    //var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO == projNumber && DateTime.Parse(r.RUN_DATETIME)<= DateTime.Now);
116
                    //var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO == projNumber);
117
                    var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO != null);
118

    
119
                    if (_RunProjects.Count() > 0)
120
                    {
121
                        _result = SendKcom(rev_No, document_No, document_Name, group_No, prj_No, document_Id, document_Url,ignoreComment);
122
                    }
123
                    else
124
                    {
125
                        _result = false.ToString();
126
                    }
127
                }
128
            }
129
            catch (Exception ex)
130
            {
131
                _result = ex.Message.ToString();
132
                SendNotice("Project NO : " + prj_No + "\r\n  DocumentUrl : " + document_Url + "\r\n Error" + ex.ToString());
133
            }
134
            return _result;
135
        }
136

    
137
        private string SendKcom(string rev_No, string document_No, string document_Name, string group_No, string prj_No, string document_Id, string document_Url, string ignoreComment)
138
        {
139
            string result = false.ToString();
140

    
141
            if (remObj == null)
142
            {
143
                result = "Window Service Connection Error";
144
            }
145
            else
146
            {
147
                //string _id = GetGuid(0, GuidGenerator.GetUniqueGuid()).ToString();
148
                string _id = shortGuid();
149
                string _doc_id = ((UInt32)document_Id.GetHashCode()).ToString();
150
                
151
                using (DeepView_Entity _entity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
152
                {
153
                    if (string.IsNullOrEmpty(group_No))
154
                    {
155
                        group_No = "0";
156
                    }
157
                    if (!document_Url.Contains("http%3a%2f%2f"))
158
                    {
159
                        document_Url = Base64Decode(document_Url);
160
                        document_Url = HttpUtility.UrlEncodeUnicode(document_Url);
161
                    }
162
                    document_Name = Base64DecodeFromStr(document_Name);
163
                    var doc = _entity.DOCUMENT_ITEM.Where(d => d.ID == document_Id).FirstOrDefault();
164
                    if (doc != null)
165
                    {
166
                        if (bool.Parse(ignoreComment))
167
                        {
168
                            try
169
                            {
170
                                var docinfo = _entity.DOCINFO.Where(x => x.DOCUMENT_ID == doc.DOCUMENT_ID).FirstOrDefault();
171
                                var markupinfos = _entity.MARKUP_INFO.Where(x => x.DOCINFO_ID == docinfo.ID).ToList();
172
                                foreach (var markupinfo in markupinfos)
173
                                {
174
                                    var markupinfoversions = _entity.MARKUP_INFO_VERSION.Where(x => x.MARKUPINFO_ID == markupinfo.ID).ToList();
175
                                    foreach (var markupinfoversion in markupinfoversions)
176
                                    {
177
                                        var markupdatas = _entity.MARKUP_DATA.Where(x => x.MARKUPINFO_VERSION_ID == markupinfoversion.ID).ToList();
178
                                        foreach (var markupdata in markupdatas)
179
                                        {
180
                                            _entity.DeleteObject(markupdata);
181
                                        }
182
                                        _entity.DeleteObject(markupinfoversion);
183
                                    }
184
                                    _entity.DeleteObject(markupinfo);
185
                                }
186
                                _entity.SaveChanges();
187
                            }
188
                            catch (Exception ex)
189
                            {
190
                                result = "deleteobject error:"+ex.ToString();
191
                            }
192
                                                    
193
                        }else
194
                        {
195
                            doc.REVISION = rev_No;
196
                            doc.ORIGINAL_FILE = document_Url;
197
                            doc.GROUP_NO = group_No;
198
                            doc.DOCUMENT_NO = document_No;
199
                            doc.DOCUMENT_NAME = document_Name;
200
                        }                        
201
                    }else
202
                    {
203
                        _entity.AddToDOCUMENT_ITEM(new DOCUMENT_ITEM
204
                        {
205
                            ID = document_Id,
206
                            REVISION = rev_No,
207
                            DOCUMENT_NO = document_No,
208
                            DOCUMENT_NAME = document_Name,
209
                            GROUP_NO = group_No,
210
                            ORIGINAL_FILE = document_Url,
211
                            DOCUMENT_ID = _doc_id,
212
                            PROJECT_NO = prj_No,
213
                        });                        
214
                    }                    
215
                    
216
                    _entity.AddToCONVERTER_DOC(new CONVERTER_DOC
217
                    {
218
                        ID = _id,
219
                        CREATE_DATETIME = DateTime.Now,
220
                        DOCUMENT_URL = document_Url,
221
                        PROJECT_NO = prj_No,
222
                        DOCUMENT_ID = _doc_id,
223
                    });
224
                    _entity.SaveChanges();
225
                }
226

    
227
                if (Properties.Settings.Default.MARKUS_V3_PROJECTS.Split(',').Contains(prj_No))
228
                {
229
                    try
230
                    {
231
                        System.Net.WebClient client = new System.Net.WebClient();
232
                        var convertResult = client.DownloadString($"{Properties.Settings.Default.MARKUS_V3_ADDRESS}/Rest/ConvertAdd?ProjectNo={prj_No}&DocumentID={_id}");
233

    
234
                        JObject jObject = JObject.Parse(convertResult, new JsonLoadSettings());
235
                        result = jObject["ConvertAddResult"].ToString();
236
                    }
237
                    catch (Exception ex)
238
                    {
239
                        result = $"Markus V3 Connect Error {ex.Message}";
240
                    }
241
                }
242
                else
243
                {
244
                    var convertResult = remObj.SetConverterPDF(prj_No, _id);
245

    
246
                    if (convertResult.Exception != null)
247
                    {
248
                        result = false.ToString();
249
                    }
250
                    else
251
                    {
252
                        result = true.ToString();
253
                    }
254
                }
255

    
256
            }
257

    
258
            return result;
259
        }
260
        [WebMethod]
261
        public string ManualConvert(string rev_No, string document_No, string document_Name, string group_No, string prj_No, string document_Id, string document_Url)
262
        {
263
            string _result = null;
264
            try
265
            {
266
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
267
                {
268
                    //_result = ConnectStringBuilder.DeepViewConnectionString().ToString();
269
                    //var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO == projNumber && DateTime.Parse(r.RUN_DATETIME)<= DateTime.Now);
270
                    //var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO == projNumber);
271
                    var _RunProjects = deepViewEntity.RUN_PROJECTS.Where(r => r.PROJECT_NO != null);
272

    
273
                    if (_RunProjects.Count() > 0)
274
                    {
275
                        _result = ManualSendKcom(rev_No, document_No, document_Name, group_No, prj_No, document_Id, document_Url);
276
                    }
277
                    else
278
                    {
279
                        _result = false.ToString();
280
                    }
281
                }
282
            }
283
            catch (Exception ex)
284
            {
285
                logger.Error("Conversion Web Service ManualConvert Error", ex);
286
                _result = ex.Message.ToString();
287
                SendNotice("Project NO : " + prj_No + "\r\n  DocumentUrl : " + document_Url + "\r\n Error" + ex.ToString());
288
            }
289
            return _result;
290
        }
291
        [WebMethod]
292
        public string UpdateUrlEncode(string EnsembleId)
293
        {
294
            string _result = null;
295
            try
296
            {
297
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
298
                {
299
                    var doc = deepViewEntity.DOCUMENT_ITEM.Where(data => data.ID == EnsembleId).FirstOrDefault();
300
                    string url = doc.ORIGINAL_FILE;
301
                    if (url.Contains("http://"))
302
                    {
303
                        //기존 url 이 인코딩 안되 있으면 인코딩 작업.
304
                        url = HttpUtility.UrlEncodeUnicode(url);
305
                        doc.ORIGINAL_FILE = url;
306

    
307
                        var convertdoc = deepViewEntity.CONVERTER_DOC.Where(d => d.DOCUMENT_ID == doc.DOCUMENT_ID).FirstOrDefault();
308
                        if(convertdoc != null)
309
                            convertdoc.DOCUMENT_URL = url;
310
                        var docinfo = deepViewEntity.DOCINFO.Where(d => d.DOCUMENT_ID == doc.DOCUMENT_ID).FirstOrDefault();
311
                        if(docinfo != null)
312
                            docinfo.ORIGINAL_FILE = url;
313
                    }
314
                        
315
                    deepViewEntity.SaveChanges();
316
                }
317
            }
318
            catch (Exception ex)
319
            {
320
                logger.Error("Conversion Web Service UpdateUrlEncode Error", ex);
321
                _result = ex.Message.ToString();
322
            }
323
            return _result;
324
        }
325
        public string Base64DecodeFromStr(string data)
326
        {
327
            try
328
            {
329
                System.Text.UTF8Encoding encoder = new System.Text.UTF8Encoding();
330
                System.Text.Decoder utf8Decode = encoder.GetDecoder();
331

    
332
                byte[] todecode_byte = Convert.FromBase64String(data);
333

    
334
                int charCount = utf8Decode.GetCharCount(todecode_byte, 0, todecode_byte.Length);
335

    
336
                char[] decoded_char = new char[charCount];
337

    
338
                utf8Decode.GetChars(todecode_byte, 0, todecode_byte.Length, decoded_char, 0);
339

    
340
                string result = new String(decoded_char);
341

    
342
                return result;
343
            }
344
            catch (Exception)
345
            {
346
                return data;
347
            }
348
        }
349
        public string Base64Decode(string data)
350
        {
351
            try
352
            {
353
                if(data.Contains("http://"))
354
                {
355
                    return data;
356
                }else
357
                {
358
                    System.Text.UTF8Encoding encoder = new System.Text.UTF8Encoding();
359
                    System.Text.Decoder utf8Decode = encoder.GetDecoder();
360

    
361
                    byte[] todecode_byte = Convert.FromBase64String(data);
362

    
363
                    int charCount = utf8Decode.GetCharCount(todecode_byte, 0, todecode_byte.Length);
364

    
365
                    char[] decoded_char = new char[charCount];
366

    
367
                    utf8Decode.GetChars(todecode_byte, 0, todecode_byte.Length, decoded_char, 0);
368

    
369
                    string result = new String(decoded_char);
370

    
371
                    return result;
372
                }
373
                
374

    
375
            }
376

    
377
            catch (Exception e)
378
            {
379
                throw new Exception("Error in Base64Decode: " + e.Message);
380
            }
381
        }
382
        [WebMethod]
383
        public string UpdateSlip(string EnsembleId, string SlipNo, string slipLink)
384
        {
385
            string _result = null;
386
            try
387
            {
388
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
389
                {
390
                    var doc = deepViewEntity.DOCUMENT_ITEM.Where(data => data.ID == EnsembleId).FirstOrDefault();
391
                    if(!string.IsNullOrEmpty(SlipNo))
392
                        doc.GROUP_NO = SlipNo;
393
                    if(!string.IsNullOrEmpty(slipLink))
394
                    {
395
                        if (!slipLink.Contains("http://"))
396
                            slipLink = Base64Decode(slipLink);
397
                        //throw new Exception("doc.ENSEMBLEINFO_URL not support");
398
                        doc.ENSEMBLEINFO_URL = slipLink;
399
                    }
400
                    
401
                    deepViewEntity.SaveChanges();
402
                }
403
            }
404
            catch (Exception ex)
405
            {
406
                logger.Error($"Conversion Web Service UpdateSlip Error EnsembleId : {EnsembleId} SlipNo : {SlipNo}   slipLink: {slipLink}", ex);
407
                _result = ex.Message.ToString();                
408
            }
409
            return _result;
410
        }
411
        [WebMethod]
412
        public string UpdateResult(string EnsembleId, string Result, string FinalPDFUrl)
413
        {
414
            string _result = null;
415
            try
416
            {
417
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
418
                {
419
                    var doc = deepViewEntity.DOCUMENT_ITEM.Where(data => data.ID == EnsembleId).FirstOrDefault();
420
                    doc.RESULT = Result;
421
                    doc.RESULT_FILE = FinalPDFUrl;
422
                    deepViewEntity.SaveChanges();
423
                }
424
            }
425
            catch (Exception ex)
426
            {
427
                logger.Error("Conversion Web Service UpdateResult Error", ex);
428
                _result = ex.Message.ToString();
429
            }
430
            return _result;
431
        }
432
        [WebMethod]
433
        public string UpdateVP(string EnsembleId, string rev_No, string document_No, string document_Name, string pdf_url)
434
        {
435
            string _result = null;
436
            try
437
            {
438
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
439
                {
440
                    var doc = deepViewEntity.DOCUMENT_ITEM.Where(data => data.ID == EnsembleId).FirstOrDefault();
441
                    if(!string.IsNullOrEmpty(rev_No))
442
                        doc.REVISION = rev_No;
443
                    if (!string.IsNullOrEmpty(document_No))
444
                        doc.DOCUMENT_NO = document_No;
445
                    if (!string.IsNullOrEmpty(document_Name))
446
                        doc.DOCUMENT_NAME = document_Name;
447
                    if (!string.IsNullOrEmpty(pdf_url))
448
                    {
449
                        string url = pdf_url;
450
                        if (!doc.PROJECT_NO.Equals("150128"))
451
                        {   
452
                            url = HttpUtility.UrlEncodeUnicode(url);
453
                        }
454
                        doc.ORIGINAL_FILE = url;
455
                    }                        
456
                    deepViewEntity.SaveChanges();
457
                }
458
            }
459
            catch (Exception ex)
460
            {
461
                logger.Error("Conversion Web Service UpdateVP Error", ex);
462
                _result = ex.Message.ToString();
463
            }
464
            return _result;
465
        }
466

    
467
        [WebMethod]
468
        public string UpdatePDFUrl(string EnsembleId, string original_url, string result_url)
469
        {
470
            string _result = null;
471
            try
472
            {
473
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
474
                {
475
                    var doc = deepViewEntity.DOCUMENT_ITEM.Where(data => data.ID == EnsembleId).FirstOrDefault();
476
                    
477
                    if (!string.IsNullOrEmpty(original_url))
478
                    {
479
                        string url = original_url;
480
                        url = Base64Decode(url);
481
                        url = HttpUtility.UrlEncodeUnicode(url);
482
                        doc.ORIGINAL_FILE = url;
483
                    }
484
                    if (!string.IsNullOrEmpty(result_url))
485
                    {
486
                        doc.RESULT_FILE = result_url;
487
                    }                    
488
                    deepViewEntity.SaveChanges();
489
                    _result = true.ToString();
490
                }
491
            }
492
            catch (Exception ex)
493
            {
494
                logger.Error("Conversion Web Service UpdateVP Error", ex);
495
                _result = ex.Message.ToString();
496
            }
497
            return _result;
498
        }
499

    
500
        [WebMethod]
501
        public string DeleteVP(string id)
502
        {
503
            string _result = null;
504
            try
505
            {
506
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
507
                {
508
                    var doc = deepViewEntity.DOCUMENT_ITEM.Where(data => data.ID == id).FirstOrDefault();
509

    
510
                    if (doc != null)
511
                    {
512
                        doc.DOCUMENT_NO = "VOID_" + doc.DOCUMENT_NO;
513
                        doc.GROUP_NO = "VOID_" + doc.GROUP_NO;
514
                        //deepViewEntity.DeleteObject(doc);
515
                        deepViewEntity.SaveChanges();
516
                        _result = true.ToString();
517
                    }
518
                    else
519
                        _result = "document not found.";
520
                }
521
            }
522
            catch (Exception ex)
523
            {
524
                logger.Error("Conversion Web Service DeleteVP Error", ex);
525
                _result = ex.Message.ToString();
526
            }
527
            return _result;
528
        }
529
        [WebMethod]
530
        public string getDocumentID(string id)
531
        {
532
            string _doc_id = ((UInt32)id.GetHashCode()).ToString();
533
            return _doc_id;
534
        }
535
        [WebMethod]
536
        public string CoverConvert(string prj_No, string _id)
537
        {
538
            string _result = null;
539
            try
540
            {
541
                SendCoverConvert(prj_No, _id);
542
            }
543
            catch (Exception ex)
544
            {
545
                logger.Error("Conversion Web Service CoverConvert Error", ex);
546
                _result = ex.Message.ToString();
547
            }
548
            return _result;
549
        }
550
        private string SendCoverConvert(string prj_No, string _id)
551
        {
552
            if (remObj == null)
553
            {
554
                return "Window Service Connection Error";
555
            }
556
            else
557
            {
558
                var _result = remObj.SetConverterCoverPDF(prj_No, _id);
559

    
560
                if (_result.Exception != null)
561
                {
562
                    return false.ToString();
563
                }
564
                else
565
                {
566
                    return true.ToString();
567
                }
568
            }
569
        }
570
        private string SendKcom(string rev_No, string document_No, string document_Name, string group_No, string prj_No, string document_Id, string document_Url)
571
        {
572
            string result = false.ToString();
573

    
574
            if (remObj == null)
575
            {
576
                result  = "Window Service Connection Error";
577
            }
578
            else
579
            {
580
                //string _id = GetGuid(0, GuidGenerator.GetUniqueGuid()).ToString();
581
                string _id = shortGuid();
582
                string _doc_id = ((UInt32)document_Id.GetHashCode()).ToString();
583
                using (DeepView_Entity _entity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
584
                {
585
                    if (string.IsNullOrEmpty(group_No))
586
                    {
587
                        group_No = "0";
588
                    }
589
                    if (!document_Url.Contains("http%3a%2f%2f"))
590
                    {
591
                        document_Url = Base64Decode(document_Url);
592
                        document_Url = HttpUtility.UrlEncodeUnicode(document_Url);
593
                    }
594
                    document_Name = Base64DecodeFromStr(document_Name);
595
                    var doc = _entity.DOCUMENT_ITEM.Where(d => d.ID == document_Id).FirstOrDefault();
596
                    if(doc != null)
597
                    {
598
                        doc.DOCUMENT_ID = _doc_id;
599
                        doc.REVISION = rev_No;                        
600
                        doc.GROUP_NO = group_No;
601
                        doc.DOCUMENT_NO = document_No;
602
                        doc.DOCUMENT_NAME = document_Name;
603
                        doc.ORIGINAL_FILE = document_Url;
604
                    }
605
                    else
606
                    {                        
607
                        _entity.AddToDOCUMENT_ITEM(new DOCUMENT_ITEM
608
                        {
609
                            ID = document_Id,
610
                            REVISION = rev_No,
611
                            DOCUMENT_NO = document_No,
612
                            DOCUMENT_NAME = document_Name,
613
                            GROUP_NO = group_No,
614
                            ORIGINAL_FILE = document_Url,
615
                            DOCUMENT_ID = _doc_id,
616
                            PROJECT_NO = prj_No,
617
                        });
618
                    }
619
                    
620
                    _entity.AddToCONVERTER_DOC(new CONVERTER_DOC
621
                    {
622
                        ID = _id,
623
                        CREATE_DATETIME = DateTime.Now,
624
                        DOCUMENT_URL = document_Url,
625
                        PROJECT_NO = prj_No,
626
                        DOCUMENT_ID = _doc_id,
627
                    });
628
                    _entity.SaveChanges();
629
                }
630

    
631
                if (Properties.Settings.Default.MARKUS_V3_PROJECTS.Split(',').Contains(prj_No))
632
                {
633
                    try
634
                    {
635
                        System.Net.WebClient client = new System.Net.WebClient();
636
                        var convertResult = client.DownloadString($"{Properties.Settings.Default.MARKUS_V3_ADDRESS}/Rest/ConvertAdd?ProjectNo={prj_No}&DocumentID={_id}");
637

    
638
                        JObject jObject = JObject.Parse(convertResult, new JsonLoadSettings());
639
                        result = jObject["ConvertAddResult"].ToString();
640
                    }
641
                    catch (Exception ex)
642
                    {
643
                        logger.Error("Conversion Web Service SendKcom Error", ex);
644
                        result = $"Markus V3 Connect Error {ex.Message}";
645
                    }
646
                }
647
                else
648
                {
649
                    var convertResult = remObj.SetConverterPDF(prj_No, _id);
650

    
651
                    if (convertResult.Exception != null)
652
                    {
653
                        result = false.ToString();
654
                    }
655
                    else
656
                    {
657
                        result = true.ToString();
658
                    }
659
                }
660

    
661
            }
662

    
663
            return result;
664
        }
665
                
666
        private string ManualSendKcom(string rev_No, string document_No, string document_Name, string group_No, string prj_No, string document_Id, string document_Url)
667
        {
668
            if (remObj == null)
669
            {
670
                return "Window Service Connection Error";
671
            }
672
            else
673
            {
674
                //string _id = GetGuid(0, GuidGenerator.GetUniqueGuid()).ToString();
675
                string _id = shortGuid();
676
                string _doc_id = ((UInt32)document_Id.GetHashCode()).ToString();
677
                using (DeepView_Entity _entity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
678
                {
679
                    var doc = _entity.DOCUMENT_ITEM.Where(d => d.ID == document_Id).FirstOrDefault();
680
                    if (doc != null)
681
                    {
682
                        var converterdoc = _entity.CONVERTER_DOC.Where(c => c.DOCUMENT_ID == doc.DOCUMENT_ID).FirstOrDefault();
683
                        _entity.DeleteObject(converterdoc);
684
                        _entity.DeleteObject(doc);
685
                        _entity.SaveChanges();
686
                        document_Url = HttpUtility.UrlDecode(document_Url);
687
                    }
688
                    int cnt = _entity.DOCUMENT_ITEM.ToList().Count;
689
                    if (string.IsNullOrEmpty(group_No))
690
                    {
691
                        group_No = "0";
692
                    }
693
                    
694
                    _entity.AddToDOCUMENT_ITEM(new DOCUMENT_ITEM
695
                    {
696
                        ID = document_Id,
697
                        REVISION = rev_No,
698
                        DOCUMENT_NO = document_No,
699
                        DOCUMENT_NAME = document_Name,
700
                        GROUP_NO = group_No,
701
                        ORIGINAL_FILE = HttpUtility.UrlEncodeUnicode(document_Url),
702
                        DOCUMENT_ID = _doc_id,
703
                        PROJECT_NO = prj_No,
704
                    });
705
                    _entity.AddToCONVERTER_DOC(new CONVERTER_DOC
706
                    {
707
                        ID = _id,
708
                        CREATE_DATETIME = DateTime.Now,
709
                        DOCUMENT_URL = HttpUtility.UrlEncodeUnicode(document_Url),
710
                        PROJECT_NO = prj_No,
711
                        DOCUMENT_ID = _doc_id,
712
                    });
713
                    _entity.SaveChanges();
714
                }
715
                var _result = remObj.SetConverterPDF(prj_No, _id);
716

    
717
                if (_result.Exception != null)
718
                {
719
                    return false.ToString();
720
                }
721
                else
722
                {
723
                    return true.ToString();
724
                }
725
            }
726
        }
727

    
728
        //private Guid GetGuid(int Count,Guid ID)
729
        //{
730
        //    Guid _ID = ID;
731
        //    string _id = _ID.ToString();
732
        //    DeepView_Entity _entity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString());
733

    
734
        //    if (_entity.CONVERTER_DOC.Where(c => c.ID == _id).Count() > 0)
735
        //    {
736
        //        _entity.Dispose();
737

    
738
        //        if (Count > 10)
739
        //        {
740
        //            new Exception("GetGuid : Not Generator");
741
        //        }
742

    
743
        //        if (Count < 3)
744
        //        {
745
        //            System.Threading.Thread.Sleep(3);
746
        //        }
747

    
748
        //        GetGuid(Count++,GuidGenerator.GetUniqueGuid());
749
        //    }
750

    
751
        //    return ID;
752
        //}
753

    
754
        //GUID생성(최민수 사원 수정)
755
        public string shortGuid()
756
        {
757
            byte[] bytes = new byte[16];
758
            using (var provider = System.Security.Cryptography.RandomNumberGenerator.Create())
759
            {
760
                provider.GetBytes(bytes);
761
            }
762

    
763
            var guid = new Guid(bytes);
764

    
765
            return Convert.ToBase64String(guid.ToByteArray())
766
                .Substring(0, 10)
767
                .Replace("/", "")
768
                .Replace("+", "") + DateTime.UtcNow.Ticks.ToString("x");
769
        }
770

    
771
        [WebMethod]
772
        public string ExcelExport(string project_no, string slip_no)
773
        {
774
            string _result = "false";
775
            //FileInfo fileInfo2 = new FileInfo(Path.GetTempFileName());
776
            //fileInfo2.FullName
777
            try
778
            {
779
                // Excel 첫번째 워크시트 가져오기                
780
                //application = new Excel.Application();
781
                //workbook = application.Workbooks.Open(xlsxfilepath);
782
                //worksheet = (Excel.Worksheet)workbook.Worksheets.get_Item("Sheet1");
783
                string xlsxfilepath = @"C:\WebSite\LogView\Doc_Manager\sample.xlsx";
784
                GemBox.Spreadsheet.SpreadsheetInfo.SetLicense("EXK0-W4HZ-N518-IMEW");
785
                GemBox.Spreadsheet.ExcelFile excelFile = new GemBox.Spreadsheet.ExcelFile();
786
                excelFile.LoadXlsx(xlsxfilepath, GemBox.Spreadsheet.XlsxOptions.PreserveMakeCopy);
787
                GemBox.Spreadsheet.ExcelWorksheet ws = excelFile.Worksheets[0];
788
                FileInfo fileInfo2 = new FileInfo(Path.GetTempFileName().Replace(".tmp", ".xlsx"));
789

    
790
                string fileout = @"C:\WebSite\LogView\Doc_Manager\commentexcel_" + DateTime.Now.ToString() + ".xlsx";
791
                string naspath = Properties.Settings.Default.Excelfilepath;
792
                    //@"\\172.20.121.220\comment3\TileSource\Excelexport";
793

    
794
                // 데이타 넣기
795
                int h = 6;
796
                int w = 1;
797

    
798

    
799
                //필터 기능 추가
800
                //Excel.Range Filter_Range = worksheet.Range["B9:" + Ran + "9"];
801
                //Filter_Range.AutoFilter(1, Type.Missing, Excel.XlAutoFilterOperator.xlAnd, Type.Missing, true);
802

    
803

    
804
                using (DeepView_Entity deepViewEntity = new DeepView_Entity(ConnectStringBuilder.DeepViewConnectionString().ToString()))
805
                {
806
                    var docs = deepViewEntity.DOCUMENT_ITEM.Where(doc => doc.GROUP_NO == slip_no && doc.PROJECT_NO == project_no).ToList();
807
                    if (docs.Count > 0)
808
                    {
809
                        foreach (var doc in docs)
810
                        {
811
                            var commentlist = deepViewEntity.MARKUP_DATA.Where(d => d.MARKUP_INFO_VERSION.MARKUP_INFO.DOCINFO.DOCUMENT_ID == doc.DOCUMENT_ID
812
                            && d.MARKUP_INFO_VERSION.MARKUP_INFO.CONSOLIDATE == 1).ToList();
813

    
814
                            string docNo = doc.DOCUMENT_NO;
815
                            string docDesc = doc.DOCUMENT_NAME;
816
                            string docRev = doc.REVISION;
817
                            foreach (var comment in commentlist)
818
                            {
819
                                var member = deepViewEntity.MEMBER.Where(m => m.ID == comment.MARKUP_INFO_VERSION.MARKUP_INFO.USER_ID).FirstOrDefault();
820
                                string docdept = member.DEPARTMENT;
821
                                string doccomment = string.Empty;
822
                                var data = MarkupToPDF.Serialize.Core.JsonSerializerHelper.UnCompressString(comment.DATA.ToString());
823
                                switch (Enum.Parse(typeof(MarkupToPDF.Controls.Common.ControlType), comment.DATA_TYPE.ToString()))
824
                                {
825
                                    case MarkupToPDF.Controls.Common.ControlType.TextControl:
826
                                    case MarkupToPDF.Controls.Common.ControlType.TextBorder:
827
                                    case MarkupToPDF.Controls.Common.ControlType.TextCloud:
828
                                        {
829
                                            MarkupToPDF.Serialize.S_Control.S_TextControl instance = MarkupToPDF.Serialize.Core.JsonSerializerHelper.JsonDeserialize<MarkupToPDF.Serialize.S_Control.S_TextControl>(data);
830
                                            doccomment = instance.Text;
831
                                        }
832
                                        break;
833
                                    case MarkupToPDF.Controls.Common.ControlType.ArrowTextBorderControl:
834
                                    case MarkupToPDF.Controls.Common.ControlType.ArrowTextCloudControl:
835
                                    case MarkupToPDF.Controls.Common.ControlType.ArrowTextControl:
836
                                    case MarkupToPDF.Controls.Common.ControlType.ArrowTransTextBorderControl:
837
                                    case MarkupToPDF.Controls.Common.ControlType.ArrowTransTextCloudControl:
838
                                    case MarkupToPDF.Controls.Common.ControlType.ArrowTransTextControl:
839
                                        {
840
                                            MarkupToPDF.Serialize.S_Control.S_ArrowTextControl instance = MarkupToPDF.Serialize.Core.JsonSerializerHelper.JsonDeserialize<MarkupToPDF.Serialize.S_Control.S_ArrowTextControl>(data);
841
                                            doccomment = instance.ArrowText;
842
                                        }
843
                                        break;
844
                                }
845
                                ws.Cells[h, w].Value = string.Format("{0}\n({1})", docNo, docDesc);
846
                                ws.Cells[h, w + 1].Value = docRev;
847
                                ws.Cells[h, w + 2].Value = docdept;
848
                                ws.Cells[h, w + 3].Value = doccomment;
849
                                h++;
850
                            }
851
                        }
852
                    }
853
                    else
854
                    {
855
                        _result = "ERROR : 해당 Slip 의 데이터가 없습니다.";
856
                    }
857

    
858

    
859
                }
860

    
861
                int columnCount = ws.CalculateMaxUsedColumns();
862
                for (int i = 0; i < columnCount; i++)
863
                    ws.Columns[i].AutoFit();
864
                //worksheet.Columns.AutoFit();
865
                // 엑셀파일 저장
866

    
867
                excelFile.Save(fileInfo2.FullName);
868
                fileInfo2.MoveTo(naspath + "\\" + fileInfo2.Name);
869
                //workbook.SaveAs(fileout);
870
                ////workbook.Save();
871
                //workbook.Close(true);
872
                //application.Quit();
873
                _result = Properties.Settings.Default.Excelresulturl + fileInfo2.Name;
874
            }
875
            catch (Exception e)
876
            {
877
                _result = "ERROR : " + e.ToString();
878
            }
879
            return _result;
880
        }
881

    
882
        private static void ReleaseExcelObject(object obj)
883
        {
884
            try
885
            {
886
                if (obj != null)
887
                {
888
                    obj = null;
889
                }
890
            }
891
            catch (Exception ex)
892
            {
893
                obj = null;
894
                throw ex;
895
            }
896
            finally
897
            {
898
                GC.Collect();
899
            }
900
        }
901
    }
902
}
클립보드 이미지 추가 (최대 크기: 500 MB)