프로젝트

일반

사용자정보

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

markus / KCOM_API / ServiceDeepView.svc.cs @ a7372e37

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

1
using IFinalPDF;
2
using IKCOM;
3
using KCOMDataModel.Common;
4
using KCOMDataModel.DataModel;
5
using System;
6
using System.Collections.Generic;
7
using System.Collections.ObjectModel;
8
using System.Configuration;
9
using System.Linq;
10
using System.Net;
11
using System.Runtime.Remoting.Channels.Tcp;
12
using System.Runtime.Serialization;
13
using System.ServiceModel;
14
using System.ServiceModel.Activation;
15
using System.Text;
16
using System.Web.Services;
17
using System.Windows;
18
using System.Xml;
19

    
20
namespace KCOM_API
21
{
22
    // NOTE: You can use the "Rename" command on the "Refactor" menu to change the class name "ServiceDeepView" in code, svc and config file together.
23
    // NOTE: In order to launch WCF Test Client for testing this service, please select ServiceDeepView.svc or ServiceDeepView.svc.cs at the Solution Explorer and start debugging.
24
    [ServiceContract(Namespace = "")]
25
    [AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
26
    public partial class ServiceDeepView : System.Web.Services.WebService
27
    {
28
        /// <summary>
29
        /// Client Version 과 Server Version 을 비교하여 Server Version 이 최신이면 다운로드 url 리턴.
30
        /// </summary>
31
        /// <param name="is64BitProcess">64bit = true, 32bit = false</param>
32
        /// <param name="markusVer">client version</param>
33
        /// <returns></returns>
34
        [OperationContract]
35
        public string GetVersionData(bool is64BitProcess, string markusVer)
36
        {
37
            string url = null;
38

    
39
            try
40
            {
41
                Version client_version = new Version(markusVer);
42
                
43
                //DB에서 version 정보와 다운로드 url 을 Select
44
                PROPERTIES dbvalue = null;
45
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
46
                using (KCOMEntities uc = new KCOMEntities(sConnString))
47
                {
48
                    string wherestr = string.Empty;
49
                    if (is64BitProcess)
50
                    {
51
                        wherestr = "Update_x64";                        
52
                    }
53
                    else
54
                    {
55
                        wherestr = "Update_x84";                        
56
                    }
57
                    dbvalue = uc.PROPERTIES.Where(data => data.TYPE == wherestr).FirstOrDefault();
58
                }
59

    
60
                //서버 버전이 최신이면 0보다 큰값 리턴
61
                Version server_version = new Version(dbvalue.PROPERTY);
62
                int result = server_version.CompareTo(client_version);  
63
                if (result > 0)
64
                {
65
                    url = dbvalue.VALUE;
66
                }
67
            }
68
            catch (Exception)
69
            {
70
                url = null;
71
            }
72
            return url;
73
        }
74
    
75

    
76
        [OperationContract]
77
        public KCOM_SystemInfo GetSystemData()
78
        {
79
            try
80
            {
81
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
82
                using (KCOMEntities uc = new KCOMEntities(sConnString))
83
                {
84
                    var SystemInfoSet = uc.PROPERTIES.Where(data => data.TYPE == "SystemInfo").ToList();
85

    
86
                    KCOM_SystemInfo sysInfo = new KCOM_SystemInfo();
87

    
88
                    var url = SystemInfoSet.Where(data => data.PROPERTY == "Url").FirstOrDefault();
89
                    if (url != null)
90
                    {
91
                        sysInfo.HostName = url.VALUE;
92
                    }
93

    
94
                    url = SystemInfoSet.Where(data => data.PROPERTY == "Port").FirstOrDefault();
95
                    if (url != null)
96
                    {
97
                        sysInfo.HostPort = url.VALUE;
98
                    }
99

    
100
                    url = uc.PROPERTIES.Where(data => data.TYPE == "STAMP").FirstOrDefault();
101
                    if(url != null)
102
                    {
103
                        sysInfo.STAMP = url.VALUE;
104
                    }
105
                    return sysInfo;
106
                }
107
            }
108
            catch (Exception ex)
109
            {
110
            }
111
            return null;
112
            GC.Collect(2);
113
        }
114

    
115
        private static string shortGuid()
116
        {
117
            byte[] bytes = new byte[16];
118
            using (var provider = System.Security.Cryptography.RandomNumberGenerator.Create())
119
            {
120
                provider.GetBytes(bytes);
121
            }
122

    
123
            var guid = new Guid(bytes);
124

    
125
            return Convert.ToBase64String(guid.ToByteArray())
126
                .Substring(0, 10)
127
                .Replace("/", "")
128
                .Replace("+", "") + DateTime.UtcNow.Ticks.ToString("x");
129
        }
130

    
131

    
132
        [OperationContract]
133
        public List<FAVORITE_DOC> GetFavoriteVP(string PrjNo, string userID, string sharepointItemID)
134
        {
135
            string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
136
            using (KCOMEntities dc = new KCOMEntities(sConnString))
137
            {
138

    
139
                int flagString = Convert.ToInt32(FAVORITE_FLAG.Personal);
140
                List<FAVORITE_DOC> favoriteListSet = new List<FAVORITE_DOC>();
141
                //dc.FAVORITE_DOC.Where(data => data.PROJECT_NO == PrjNo && data.DOCUMENT_ID == sharepointItemID && data.FLAG !=
142
                //    flagString).ToList().ForEach(data => favoriteListSet.Add(data));
143

    
144

    
145
                //dc.FAVORITE_DOC.Where(data => data.PROJECT_NO == PrjNo && data.MEMBER_USER_ID == userID).ToList().ForEach(data => favoriteListSet.Add(data));
146

    
147
                favoriteListSet = dc.FAVORITE_DOC.Where(data => data.PROJECT_NO == PrjNo && data.MEMBER_USER_ID == userID && data.DOCUMENT_ID == sharepointItemID).ToList();
148

    
149
                //favoriteListSet = favoriteListSet.Distinct().ToList();
150
                return favoriteListSet;
151
            }
152
        }
153
        [OperationContract]
154
        public bool EditFavoriteVP(string prjNo, string userID, string docID, int state, string description)
155
        {
156
            string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
157
            using (KCOMEntities dc = new KCOMEntities(sConnString))
158
            {
159
                //List<FAVORITE_DOC> favoriteSet = dc.FAVORITE_DOC.Where(data => data.PROJECT_NO == prjNo && data.MEMBER_USER_ID == userID
160
                //    && data.PAGE_NO == SavePageNo && data.CREATE_TIME == createTime).ToList();
161
                List<FAVORITE_DOC> favoriteSet = dc.FAVORITE_DOC.Where(data => data.PROJECT_NO == prjNo && data.MEMBER_USER_ID == userID
162
                    && data.ID == docID).ToList();
163
                try
164
                {
165

    
166
                    if (favoriteSet.Count > 0)
167
                    {
168
                        var FavoriteVP_Instance = favoriteSet.First();
169

    
170
                        FavoriteVP_Instance.DESCRIPTION = description;
171
                        FavoriteVP_Instance.FLAG = state;
172

    
173
                        dc.SaveChanges();
174

    
175
                        return true;
176
                    }
177
                    else
178
                    {
179
                        return false;
180
                    }
181
                }
182
                catch (Exception)
183
                {
184
                    return false;
185
                }
186
            }
187
        }
188

    
189
        [OperationContract]
190
        public bool DelFavoriteVP(string prjNo, string userID, int SavePageNo, string docID)
191
        {
192
            string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
193
            using (KCOMEntities dc = new KCOMEntities(sConnString))
194
            {
195

    
196
                List<FAVORITE_DOC> favoriteSet = dc.FAVORITE_DOC.Where(data => data.PROJECT_NO == prjNo && data.MEMBER_USER_ID == userID
197
                    && data.ID == docID).ToList();
198

    
199
                try
200
                {
201
                    if (favoriteSet.Count > 0)
202
                    {
203
                        favoriteSet.ForEach(data => dc.FAVORITE_DOC.DeleteObject(data));
204
                        dc.SaveChanges();
205
                        return true;
206
                    }
207
                    else
208
                    {
209
                        return false;
210
                    }
211
                }
212
                catch (Exception)
213
                {
214
                    return false;
215
                }
216
            }
217
        }
218

    
219
        /// <summary>
220
        /// 두 페이지를 비교하여 결과를 리턴한다
221
        /// </summary>
222
        /// <param name="projectNo"></param>
223
        /// <param name="originDocItem_ID"></param>
224
        /// <param name="targetDocItem_ID"></param>
225
        /// <param name="originPageNo"></param>
226
        /// <param name="targetPageNo"></param>
227
        /// <param name="isInternalAddress"></param>
228
        /// <returns></returns>
229
        [OperationContract]
230
        public List<Rect> GetCompareRect(string projectNo, string originDocItem_ID, string targetDocItem_ID, string originPageNo, string targetPageNo, string isInternalAddress)
231
        {
232
            List<Rect> result = new List<Rect>();
233

    
234
            try
235
            {
236
                string originFile = "";
237
                string targetFile = "";
238

    
239
                string sOriginFolder = originDocItem_ID.All(char.IsDigit) ? (Convert.ToUInt32(originDocItem_ID) / 100).ToString() : (originDocItem_ID.Length >= 5 ? originDocItem_ID.Substring(0, 5) : originDocItem_ID);
240
                string sTagetFolder = targetDocItem_ID.All(char.IsDigit) ? (Convert.ToUInt32(targetDocItem_ID) / 100).ToString() : (targetDocItem_ID.Length >= 5 ? targetDocItem_ID.Substring(0, 5) : targetDocItem_ID);
241

    
242
                if (Boolean.Parse(isInternalAddress))
243
                {
244
                    originFile = String.Format(KCOM_API.Properties.Settings.Default.TileSoucePath, projectNo, sOriginFolder, originDocItem_ID, originPageNo);
245
                    targetFile = String.Format(KCOM_API.Properties.Settings.Default.TileSoucePath, projectNo, sTagetFolder, targetDocItem_ID, targetPageNo);
246
                }
247
                else
248
                {
249
                    originFile = String.Format(KCOM_API.Properties.Settings.Default.TileSoucePath_SUB, projectNo, originDocItem_ID, originPageNo);
250
                    targetFile = String.Format(KCOM_API.Properties.Settings.Default.TileSoucePath_SUB, projectNo, targetDocItem_ID, targetPageNo);
251
                }
252

    
253
                using (Markus.Image.ImageComparer compareLib = new Markus.Image.ImageComparer())
254
                {
255
                    result = compareLib.CompareReturnRects(originFile, targetFile, new System.Drawing.Size(20, 20));
256
                }
257
            }
258
            catch (Exception ex)
259
            {
260
                //throw new FaultException(ex.ToString() + " Inner Exception : " + ex.InnerException?.ToString());
261
            }
262
      
263

    
264
            return result;
265
        }
266

    
267
        //[OperationContract]
268
        //public List<Rect> GetCompareRect_old(string projectNo, string originDocItem_ID, string targetDocItem_ID, string originPageNo, string targetPageNo, string isInternalAddress)
269
        //{
270
        //    System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
271

    
272
        //    stopwatch.Start();
273

    
274
        //    string originFile = "";
275
        //    string targetFile = "";
276

    
277
        //    string sFolder = originDocItem_ID.All(char.IsDigit) ? (Convert.ToUInt32(originDocItem_ID) / 100).ToString() : (originDocItem_ID.Length >= 5 ? originDocItem_ID.Substring(0, 5) : originDocItem_ID);
278
        //    if (Boolean.Parse(isInternalAddress))
279
        //    {
280
        //        originFile = String.Format(KCOM_API.Properties.Settings.Default.TileSoucePath, projectNo, sFolder, originDocItem_ID, originPageNo);
281
        //        targetFile = String.Format(KCOM_API.Properties.Settings.Default.TileSoucePath, projectNo, sFolder, targetDocItem_ID, targetPageNo);
282
        //    }
283
        //    else
284
        //    {
285
        //        originFile = String.Format(KCOM_API.Properties.Settings.Default.TileSoucePath_SUB, projectNo, originDocItem_ID, originPageNo);
286
        //        targetFile = String.Format(KCOM_API.Properties.Settings.Default.TileSoucePath_SUB, projectNo, targetDocItem_ID, targetPageNo);
287
        //    }
288

    
289
        //    CompareLib compareLib = new CompareLib();
290

    
291
        //    var resultOrigin = compareLib.ChangeCmpUrlToPng_File(originFile);
292
        //    var resultTarget = compareLib.ChangeCmpUrlToPng_File(targetFile);
293

    
294
        //    string outPutFile = compareLib.ImageCompare_File(resultOrigin, resultTarget);
295
        //    var result = compareLib.GetBoundBoxInImage(outPutFile);
296

    
297
        //    System.Diagnostics.Debug.WriteLine(new TimeSpan(stopwatch.ElapsedTicks));
298

    
299
        //    return result;
300
        //}
301

    
302

    
303
        #region Final PDF
304
        private string _ChanID = null;
305
        TcpChannel chan = null;
306
        [OperationContract]
307
        public FinalPDFResult SetFinalPDF(string ProjectNo, string DocInfoID, string MarkupInfoID, string CreateUserID)
308
        {
309
            #region 임시보관
310
            #endregion
311
            FinalPDFResult _result = new FinalPDFResult();
312
            RemFinalPDFObject remObj = null;
313
            try
314
            {
315
                string _finalID = shortGuid();
316
                int _DocTotalPages = -1;
317
                string docItemId;
318

    
319
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
320
                using (CIEntities _ci = new CIEntities(sCIConnString))
321
                {
322
                    var _doc = _ci.DOCINFO.Where(info => info.ID == DocInfoID);
323

    
324
                    if (_doc.Count() > 0)
325
                    {
326
                        _DocTotalPages = _doc.First().PAGE_COUNT;
327
                        docItemId = _doc.First().DOCUMENT_ID;
328
                    }
329
                    else
330
                    {
331
                        _result.Status = FinalStatus.Error;
332
                        _result.Exception = "페이지 정보를 가져올 수 없습니다.";
333
                        return _result;
334
                    }
335
                }
336
                if (_DocTotalPages > 0)
337
                {
338
                    FINAL_PDF fm = new FINAL_PDF()
339
                    {
340
                        ID = _finalID,
341
                        PROJECT_NO = ProjectNo,
342
                        DOCINFO_ID = DocInfoID,
343
                        DOCUMENT_ID = docItemId,
344
                        MARKUPINFO_ID = MarkupInfoID,
345
                        CREATE_USER_ID = CreateUserID,
346
                        TOTAL_PAGE = _DocTotalPages,
347
                        CREATE_DATETIME = DateTime.Now,
348
                        STATUS = (int)IFinalPDF.FinalStatus.Insert
349
                    };
350

    
351
                    string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
352
                    using (KCOMEntities _entity = new KCOMEntities(sConnString))
353
                    {
354
                        _entity.AddToFINAL_PDF(fm);
355
                        _entity.SaveChanges(System.Data.Objects.SaveOptions.AcceptAllChangesAfterSave);
356
                    };
357

    
358
                    System.Runtime.Remoting.Channels.IChannel _ch = System.Runtime.Remoting.Channels.ChannelServices.GetChannel("tcp");
359
                    if (_ch == null)
360
                    {
361
                        chan = new TcpChannel();
362
                        _ChanID = chan.ChannelName;
363
                        System.Runtime.Remoting.Channels.ChannelServices.RegisterChannel(chan, false);
364
                        // Create an instance of the remote object
365

    
366
                        using (KCOMEntities ec = new KCOMEntities(sConnString))
367
                        {
368

    
369
                            //remObj = (RemFinalPDFObject)Activator.GetObject(typeof(RemFinalPDFObject),
370
                            //                          "tcp://localhost:9092/remFinalPDF");
371
                            remObj = (RemFinalPDFObject)Activator.GetObject(typeof(RemFinalPDFObject),
372
                                                      //"tcp://192.168.0.67:9092/remFinalPDF");
373
                                                      "tcp://localhost:9092/remFinalPDF");
374
                        }
375

    
376
                        //"tcp://localhost:8080/remFinalPDF");
377

    
378
                        _result = remObj.SetFinalPDF(ProjectNo, _finalID);
379
                        _result.FinalID = _finalID;
380
                        _result.Status = FinalStatus.Success;
381

    
382
                        //MarkupToPDF.MarkupToPDF fa = new MarkupToPDF.MarkupToPDF();
383
                        //fa.MakeFinalPDF(fm);
384
                    }
385
                    else
386
                    {
387
                        _ChanID = _ch.ChannelName;
388
                    }
389
                }
390
            }
391
            catch (Exception ex)
392
            {
393
                _result.Status = FinalStatus.Error;
394

    
395
                if (ex.GetType() == typeof(System.Net.Sockets.SocketException))
396
                    _result.Exception = "Final Server Not Connection";
397
                else _result.Exception = ex.ToString();
398
            }
399
            finally
400
            {
401
                remObj = null;
402
                if (System.Runtime.Remoting.Channels.ChannelServices.GetChannel("tcp") != null)
403
                    System.Runtime.Remoting.Channels.ChannelServices.UnregisterChannel(chan);
404

    
405
                GC.Collect(2);
406
            }
407
            return _result;
408
        }
409
        #endregion
410

    
411

    
412
        [OperationContract]
413
        public bool GetConversionState(KCOM_BasicParam param)
414
        {
415
            string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
416
            using (CIEntities entity = new CIEntities(sCIConnString))
417
            {
418
                var doc = entity.DOCINFO.Where(data => data.DOCUMENT_ID == param.documentID).FirstOrDefault();
419
                if (doc != null)
420
                {
421
                    var count = doc.DOCPAGE.Where(data => data.DOCINFO_ID == doc.ID).Count();
422
                    if (doc.PAGE_COUNT == count)  //페이지 수가 일치하는지
423
                    {
424
                        return true;
425
                    }
426
                    else //페이지 수가 일치하지 않는 경우
427
                    {
428
                        string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
429
                        KCOMEntities entity_kcom = new KCOMEntities(sConnString);
430
                        var lst = entity_kcom.CONVERTER_DOC.Where(data => data.PROJECT_NO == param.projectNo && data.DOCUMENT_ID == param.documentID && data.TOTAL_PAGE != doc.PAGE_COUNT).ToList();
431

    
432
                        if (lst != null || lst.Count >= 1)
433
                        {
434
                            //Common.Helper.SystemErrorNotify(SERVICE_NAME.API, LEVEL.MEDIUM, ERROR_TYPE.CONVERT, Resources.ResourceManager.GetString("MSG_ERROR_PAGECOUNT"), param.documentID, param.projectNo);
435
                            //이메일 클라이언트를 구현해야함
436
                        }
437
                        return false;
438
                    }
439
                }
440
                else
441
                {
442
                    //Common.Helper.SystemErrorNotify(SERVICE_NAME.API, LEVEL.MEDIUM, ERROR_TYPE.CONVERT, Resources.ResourceManager.GetString("MSG_ERROR_CONVERTFAILED"), param.documentID, param.projectNo);
443
                    //이메일 클라이언트를 구현해야함
444
                    return false;
445
                }
446
            }
447
        }
448

    
449
        [OperationContract]
450
        public List<VPRevision> GetVPRevisionHistory(string ProjectNo, string vpNo, string DocumentId)
451
        {
452
            List<VPRevision> _result = new List<VPRevision>();
453
            try
454
            {
455
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
456
                using (CIEntities entity = new CIEntities(sCIConnString))
457
                {
458
                    var _vpList = (from docitem in entity.DOCUMENT_ITEM
459
                                   where docitem.DOCUMENT_NO == vpNo
460
                                   select new VPRevision
461
                                   {
462
                                       RevNo = docitem.REVISION,
463
                                       GroupNo = docitem.GROUP_NO,
464
                                       FROM_VENDOR = docitem.ORIGINAL_FILE,
465
                                       DOCUMENT_ID = docitem.DOCUMENT_ID,
466
                                       TO_VENDOR = docitem.RESULT_FILE,
467
                                       RESULT = docitem.RESULT,
468
                                       DocNo = docitem.DOCUMENT_NO,
469
                                       //EnsembleLink = docitem.ENSEMBLEINFO_URL,
470
                                       //IsSyncPossible = docitem.DOCUMENT_ID == DocumentId ? false : entity.DOCINFO.Where(d => d.DOCUMENT_ID == docitem.DOCUMENT_ID).ToList().Count > 0 ? true : false
471
                                   });
472
                    _result = _vpList.ToList();
473
                    foreach (var vp in _result)
474
                    {
475
                        if (entity.DOCINFO.Where(d => d.DOCUMENT_ID == vp.DOCUMENT_ID).ToList().Count > 0)
476
                            vp.IsSyncPossible = true;
477
                        else
478
                            vp.IsSyncPossible = false;
479
                    }
480

    
481
                    //_result = _result.OrderByDescending(r => UInt64.Parse(System.Text.RegularExpressions.Regex.Replace(r.GroupNo, @"\D", ""))).ToList();
482
                    _result =  _result.OrderByDescending(r => r.GroupNo).ToList();
483
                }
484
            }
485
            catch (Exception ex)
486
            {
487

    
488
                throw ex;
489
            }
490
            finally
491
            {
492
                GC.Collect(2);
493
            }
494
            return _result;
495
        }
496

    
497
        [OperationContract]
498
        public VPRevision GetVPRevisionFirstOrDefault(string ProjectNo, string DocumentId)
499
        {
500
            VPRevision _result = null;
501
            try
502
            {
503
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
504
                using (CIEntities entity = new CIEntities(sCIConnString))
505
                {
506
                    _result = (from docitem in entity.DOCUMENT_ITEM
507
                     where docitem.DOCUMENT_ID == DocumentId
508
                     select new VPRevision
509
                     {
510
                         RevNo = docitem.REVISION,
511
                         GroupNo = docitem.GROUP_NO,
512
                         FROM_VENDOR = docitem.ORIGINAL_FILE,
513
                         DOCUMENT_ID = docitem.DOCUMENT_ID,
514
                         TO_VENDOR = docitem.RESULT_FILE,
515
                         RESULT = docitem.RESULT
516
                     }).FirstOrDefault();
517
                }
518
            }
519
            catch (Exception)
520
            {
521
                throw;
522
            }
523
            finally
524
            {
525
                GC.Collect(2);
526
            }
527
            return _result;
528
        }
529

    
530
        [OperationContract]
531
        public DOCINFO GetDocInfo(KCOM_BasicParam param)
532
        {
533
            DOCINFO _result = null;
534
            try
535
            {
536
                // 차후 아래의 코드로 변경
537
                //using (CI_Entities ModelDeeview = new CI_Entities(DaelimCiConnectionString.ToString()))
538
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
539
                CIEntities ModelDeeview = new CIEntities(sCIConnString);
540

    
541
                var docinfo = ModelDeeview.DOCINFO.Where(doc => doc.DOCUMENT_ID == param.documentID && doc.PROJECT_NO == param.projectNo);
542
                if (docinfo.Count() > 0)
543
                {
544
                    _result = docinfo.First();
545
                    _result.MARKUP_INFO.Clear();
546

    
547
                }
548
                return _result;
549

    
550
            }
551
            catch (Exception ex)
552
            {
553
                System.Diagnostics.Trace.WriteLine("GetDocInfo Error : " + ex);
554
            }
555
            finally
556
            {
557
                GC.Collect(2);
558
            }
559
            return null;
560
        }
561

    
562
        [OperationContract]
563
        public bool GetCheckSystemAdmin(string UserID)
564
        {
565
            string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
566
            using (KCOMEntities uc = new KCOMEntities(sConnString))
567
            {
568
                var user = uc.PROPERTIES.Where(data => data.TYPE == "Administrator" && data.PROPERTY.Contains(UserID)).FirstOrDefault();
569
                if (user != null)
570
                {
571
                    return true;
572
                }
573
                else
574
                {
575
                    return false;
576
                }
577
            }
578
            GC.Collect(2);
579
        }
580

    
581
        [OperationContract]
582
        public DOCUMENT_ITEM GetDocumentItemInfo(KCOM_BasicParam param)
583
        {
584
            ///param : prjNo, documentId, userId
585
            DOCUMENT_ITEM _result = null;
586

    
587
            try
588
            {
589
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
590
                CIEntities entity = new CIEntities(sCIConnString);
591
               
592
                var _items = entity.DOCUMENT_ITEM.Where(data => data.DOCUMENT_ID == param.documentID);
593

    
594
                if (_items.Count() > 0)
595
                {
596
                    _result = _items.First();
597

    
598
                    return _result;
599
                }
600
                //else
601
                //{
602
                //    Common.Helper.SystemErrorNotify(SERVICE_NAME.API, LEVEL.MEDIUM, ERROR_TYPE.CONVERT, Resources.ResourceManager.GetString("MSG_ERROR_DOCUMENTNOTFOUND"), param.documentID, param.projectNo);
603
                //}
604
            }
605
            catch (Exception ex)
606
            {
607
                System.Diagnostics.Trace.WriteLine("GetDocumentItemInfo Error : " + ex);
608

    
609
                new FaultException("GetDocumentItemInfo Error - "  + ex.ToString());
610
                //throw new FaultException(ex.ToString());
611
                //Common.Helper.SystemErrorNotify(SERVICE_NAME.API, LEVEL.MEDIUM, ERROR_TYPE.CONVERT, "GetDocumentItemInfo / " + ex.Message, param.documentID, param.projectNo);
612
            }
613

    
614
            return _result;
615
        }
616
        /// <summary>
617
        /// DOCUMENT_ITEM Table 의 ID 로 Item 을 Select
618
        /// </summary>
619
        /// 대림의 경우 Interface ID(Document 의 ID) 를 parameter 로 전달
620
        /// 넘어온 ID를 통해 document id 를 확인하는 과정이 필요
621
        /// <param name="ensemble_id"></param>
622
        /// <returns></returns>
623
        [OperationContract]
624
        public string GetDocItemID(string ensemble_id)
625
        {
626
            ///param : prjNo, documentId, userId
627
            string _result = string.Empty;
628

    
629
            try
630
            {
631
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
632
                CIEntities entity = new CIEntities(sCIConnString);
633

    
634
                var _items = entity.DOCUMENT_ITEM.Where(data => data.ID == ensemble_id).FirstOrDefault();
635
                if(_items != null)
636
                    _result = _items.DOCUMENT_ID;
637
            }
638
            catch (Exception ex)
639
            {
640
                //System.Diagnostics.Trace.WriteLine("GetVendorItemInfo Error : " + ex);
641
                //Common.Helper.SystemErrorNotify(SERVICE_NAME.API, LEVEL.MEDIUM, ERROR_TYPE.CONVERT, "GetDocumentItemInfo / " + ex.Message, param.documentID, param.projectNo);
642
            }
643

    
644
            return _result;
645
        }
646
        public string UserGO(MARKUP_INFO item)
647
        {
648
            if (item != null)
649
            {
650
                return item.MARKUP_INFO_VERSION.OrderByDescending(data => data.CREATE_DATE).FirstOrDefault().ID;
651
            }
652
            return null;
653
        }
654
        
655
        [OperationContract]
656
        public List<MarkupInfoItem> GetMarkupInfoItems(string ProjectNo, string DocInfoId)
657
        {
658
            List<MarkupInfoItem> _result = new List<MarkupInfoItem>();
659
            try
660
            {
661
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
662
                using (CIEntities entity = new CIEntities(sCIConnString))
663
                {
664
                    var markupListData = entity.MARKUP_INFO.Where(data => data.DOCINFO_ID == DocInfoId).ToList();
665

    
666
                    var markupList = from markup in markupListData
667
                                     orderby markup.CREATE_TIME descending
668
                                     select new MarkupInfoItem
669
                                     {
670
                                         MarkupInfoID = markup.ID,
671
                                         UserID = markup.USER_ID,
672
                                         MarkupVersionID = markup.MARKUP_INFO_VERSION.Count() == 0 ? null : markup.MARKUP_INFO_VERSION.OrderByDescending(data => data.CREATE_DATE).FirstOrDefault().ID,
673
                                         CreateTime = markup.CREATE_TIME,
674
                                         Consolidate = markup.CONSOLIDATE,
675
                                         Description = markup.DESCRIPTION,
676
                                         AvoidConsolidate = markup.AVOID_CONSOLIDATE,
677
                                         PartConsolidate = markup.PART_CONSOLIDATE,
678
                                         UpdateTime = DateTime.Parse(markup.UPDATE_TIME.ToString()),
679
                                     };
680

    
681
                    if (markupList.Count() > 0)
682
                    {
683
                        _result = markupList.ToList();
684
                    }
685

    
686
                    _result.ForEach(r =>
687
                    {
688

    
689
                        r.MarkupList = (from markupData in entity.MARKUP_DATA
690
                                        where markupData.MARKUPINFO_VERSION_ID == r.MarkupVersionID
691
                                        orderby markupData.PAGENUMBER
692
                                        select new MarkupItem { ID = markupData.ID, PageNumber = markupData.PAGENUMBER, Data = markupData.DATA, Data_Type = markupData.DATA_TYPE, Symbol_ID = markupData.SYMBOL_ID}).ToList();
693
                    });
694

    
695
                    List<PROPERTIES> _ColorsProperties = new List<PROPERTIES>();
696
                    Random random = new Random();
697

    
698
                    string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
699
                    using (KCOMEntities kcomEntity = new KCOMEntities(sConnString))
700
                    {
701
                        _ColorsProperties = (from property in kcomEntity.PROPERTIES
702
                                             where property.TYPE == "DisplayColor"
703
                                             select property).ToList();
704
                    }
705

    
706
                    bool IsProjectNoPass = Properties.Settings.Default.IsProjectNoPass;
707

    
708
                    foreach (var item in _result)
709
                    {
710
                        string query = "SELECT members.ID,members.NAME,members.DEPARTMENT FROM CIEntities.MEMBER as members where members.ID = @userId";
711

    
712
                        System.Data.Objects.ObjectQuery<System.Data.Common.DbDataRecord> memberQuery 
713
                                      = entity.CreateQuery<System.Data.Common.DbDataRecord>(query,new System.Data.Objects.ObjectParameter("userId",item.UserID));
714
                        
715
                        if (memberQuery.Count() > 0)
716
                        {
717
                            string userName = memberQuery.First()["NAME"]?.ToString().Trim();
718
                            string depatment = memberQuery.First()["DEPARTMENT"]?.ToString().Trim();
719

    
720
                            item.UserName = userName;
721
                            item.Depatment = depatment;
722
                        }
723

    
724
                        if (_ColorsProperties.Count > 0)
725
                        {
726
                            int colorIdx = random.Next(0, _ColorsProperties.Count() - 1);
727
                            #region 부서별로 색상을 지정하고자 할때
728
                            /// 일단 의견을 들어보자구!
729
                            #endregion
730
                            item.DisplayColor = "#FF" + _ColorsProperties[colorIdx].VALUE;
731
                            _ColorsProperties.Remove(_ColorsProperties[colorIdx]);
732
                        }
733
                        else
734
                        {
735
                            item.DisplayColor = String.Format("#FF{0:X6}", random.Next(0x1000000));
736
                        }
737
                    }
738
                }
739
            }
740
            catch (Exception EX)
741
            {
742
                System.Diagnostics.Debug.WriteLine(this.GetType().ToString() + " " + EX);
743
                return _result;
744
            }
745
            finally
746
            {
747
                GC.Collect(2);
748
            }
749

    
750
            return _result;
751
        }
752

    
753
        [OperationContract]
754
        public List<MarkupInfoItem> GetSyncMarkupInfoItems(string ProjectNo, string DocInfoId, string currentUser)
755
        {
756
            List<MarkupInfoItem> _result = new List<MarkupInfoItem>();
757
            try
758
            {
759
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
760
                using (CIEntities entity = new CIEntities(sCIConnString))
761
                {
762
                    var docItem = entity.DOCINFO.Where(data => data.DOCUMENT_ID == DocInfoId).FirstOrDefault();
763
                    if (docItem == null)
764
                    {
765
                        return null;
766
                    }
767
                    var markupListData = entity.MARKUP_INFO.Where(data => data.DOCINFO_ID == docItem.ID).ToList();
768

    
769
                    var markupList = from markup in markupListData
770
                                     where markup.USER_ID == currentUser || markup.CONSOLIDATE == 1
771
                                     orderby markup.CREATE_TIME descending
772
                                     select new MarkupInfoItem
773
                                     {
774
                                         MarkupInfoID = markup.ID,
775
                                         UserID = markup.USER_ID,
776
                                         MarkupVersionID = markup.MARKUP_INFO_VERSION.Count() == 0 ? null : markup.MARKUP_INFO_VERSION.OrderByDescending(data => data.CREATE_DATE).FirstOrDefault().ID,
777
                                         CreateTime = markup.CREATE_TIME,
778
                                         Consolidate = markup.CONSOLIDATE,
779
                                         Description = markup.DESCRIPTION,
780
                                         AvoidConsolidate = markup.AVOID_CONSOLIDATE,
781
                                         PartConsolidate = markup.PART_CONSOLIDATE,
782
                                     };
783

    
784

    
785

    
786
                    if (markupList.Count() > 0)
787
                    {
788
                        _result = markupList.ToList();
789
                    }
790

    
791

    
792

    
793
                    _result.ForEach(r =>
794
                    {
795

    
796
                        r.MarkupList = (from markupData in entity.MARKUP_DATA
797
                                        where markupData.MARKUPINFO_VERSION_ID == r.MarkupVersionID
798
                                        orderby markupData.PAGENUMBER
799
                                        select new MarkupItem
800
                                        {
801
                                            ID = markupData.ID,
802
                                            PageNumber = markupData.PAGENUMBER,
803
                                            Data = markupData.DATA,
804
                                            Data_Type = markupData.DATA_TYPE,
805
                                            Symbol_ID = markupData.SYMBOL_ID
806
                                        }).ToList();
807
                    });
808

    
809
                    List<PROPERTIES> _ColorsProperties = new List<PROPERTIES>();
810
                    Random random = new Random();
811

    
812
                    string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
813
                    using (KCOMEntities kcomEntity = new KCOMEntities(sConnString))
814
                    {
815
                        _ColorsProperties = (from property in kcomEntity.PROPERTIES
816
                                             where property.TYPE == "DisplayColor"
817
                                             select property).ToList();
818
                    }
819

    
820
                    foreach (var item in _result)
821
                    {
822
                        string query = "SELECT members.ID,members.NAME,members.DEPARTMENT FROM CIEntities.MEMBER as members where members.ID = @userId";
823

    
824
                        System.Data.Objects.ObjectQuery<System.Data.Common.DbDataRecord> memberQuery
825
                                      = entity.CreateQuery<System.Data.Common.DbDataRecord>(query, new System.Data.Objects.ObjectParameter("userId", item.UserID));
826

    
827
                        if (memberQuery.Count() > 0)
828
                        {
829

    
830
                            string userName = memberQuery.First()["NAME"]?.ToString().Trim();
831
                            string depatment = memberQuery.First()["DEPARTMENT"]?.ToString().Trim();
832

    
833
                            item.UserName = userName;
834
                            item.Depatment = depatment;
835
                        }
836

    
837
                        if (_ColorsProperties.Count > 0)
838
                        {
839
                            int colorIdx = random.Next(1, _ColorsProperties.Count());
840
                            #region 부서별로 색상을 지정하고자 할때
841
                            /// 일단 의견을 들어보자구!
842
                            #endregion
843
                            item.DisplayColor = "#FF" + _ColorsProperties[colorIdx].VALUE;
844
                            _ColorsProperties.Remove(_ColorsProperties[colorIdx]);
845
                            //item.DisplayColor = "#FF" + _Colors.First();
846
                            //_Colors.Remove(_Colors.First());
847
                        }
848
                        else
849
                        {
850
                            item.DisplayColor = String.Format("#FF{0:X6}", random.Next(0x1000000));
851
                        }
852
                    }
853
                }
854
            }
855
            catch (Exception EX)
856
            {
857
                System.Diagnostics.Debug.WriteLine(this.GetType().ToString() + " " + EX);
858
                return _result;
859
            }
860
            finally
861
            {
862
                GC.Collect(2);
863
            }
864

    
865
            return _result;
866
        }
867

    
868

    
869
        //[OperationContract]
870
        //[ServiceKnownType(typeof(MEMBER))]
871
        //public List<MEMBER> GetUserData(string ProjectNo, string UserID)
872
        //{
873
        //    List<MEMBER> _result = new List<MEMBER>();
874

    
875
        //    using (CIEntities entity = new CIEntities(ConnectStringBuilder.ProjectCIConnectString(ProjectNo).ToString()))
876
        //    {
877
        //        var _UserList = from member in entity.MEMBER
878
        //                        where member.ID == UserID
879
        //                        select member;
880
        //        _result = _UserList.ToList();
881
        //    }
882
        //    //GC.Collect(2);
883
        //    return _result;
884
        //}
885

    
886
        [OperationContract]
887
        [ServiceKnownType(typeof(MEMBER))]
888
        public List<MEMBER> GetUserData(string ProjectNo, string UserID)
889
        {
890
            List<MEMBER> _result = new List<MEMBER>();
891

    
892
            string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
893
            using (CIEntities entity = new CIEntities(sCIConnString))
894
            {
895
                var _UserList = from member in entity.MEMBER
896
                                where member.ID == UserID
897
                                select member;
898
                _result = _UserList.ToList();
899
            }
900
            //GC.Collect(2);
901
            return _result;
902
        }
903

    
904

    
905
        [OperationContract]
906
        public List<string> GetDeptData(string UserDept) //그룹 추가 옵션 부여 예정
907
        {
908
            List<string> _result = new List<string>();
909

    
910
            try
911
            {
912
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
913
                KCOMEntities entity = new KCOMEntities(sConnString);
914
                var YourEnginner = (from dept in entity.PROPERTIES
915
                                    where dept.TYPE == "DeptName" && UserDept.Contains(dept.VALUE)
916
                                    select dept).FirstOrDefault();
917

    
918
                if (YourEnginner != null)
919
                {
920
                    _result = (from dept in entity.PROPERTIES
921
                               where dept.PROPERTY == YourEnginner.PROPERTY
922
                               select dept.VALUE).ToList();
923
                    return _result;
924
                }
925
                else
926
                {
927
                    return null;
928
                }
929
            }
930
            catch (Exception ex)
931
            {
932
                System.Diagnostics.Debug.WriteLine(ex.Message);
933
            }
934
            finally
935
            {
936
                GC.Collect(2);
937
            }
938
            return _result;
939
        }
940

    
941
        [OperationContract]
942
        public bool DeleteMarkup(string ProjectNo, string MarkupInfoID)
943
        {
944
            bool _result = false;
945
            try
946
            {
947
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
948
                using (KCOMDataModel.DataModel.CIEntities Entity = new KCOMDataModel.DataModel.CIEntities(sCIConnString))
949
                {
950

    
951
                    MARKUP_INFO instance = Entity.MARKUP_INFO.Where(root => root.ID == MarkupInfoID).FirstOrDefault();
952

    
953
                    if (instance == null)
954
                    {
955
                        return false;
956
                    }
957
                    MARKUP_INFO_VERSION version = instance.MARKUP_INFO_VERSION.FirstOrDefault();
958

    
959

    
960
                    version.MARKUP_DATA.ToList().ForEach(data =>
961
                    {
962
                        Entity.MARKUP_DATA.DeleteObject(data);
963
                        Entity.SaveChanges();
964
                    });
965

    
966
                    Entity.MARKUP_INFO_VERSION.DeleteObject(version);
967
                    Entity.SaveChanges();
968

    
969
                    Entity.MARKUP_INFO.DeleteObject(instance);
970
                    Entity.SaveChanges();
971

    
972
                }
973
                _result = true;
974
            }
975
            catch (Exception ex)
976
            {
977
                System.Diagnostics.Trace.WriteLine(ex, "SaveMarkup");
978
            }
979
            finally
980
            {
981
                GC.Collect(2);
982
            }
983
            return _result;
984
        }
985

    
986
        #region Favorite
987
        [OperationContract]
988
        public bool SetFavoriteVP(string prjNo, string userID, string groupNo, string docNo, string rev, int SavePageNo, string documentItemID, string VPDescription, IKCOM.FAVORITE_FLAG flag)
989
        {
990
            string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
991
            using (KCOMEntities entity = new KCOMEntities(sConnString))
992
            {
993
                try
994
                {
995
                    entity.FAVORITE_DOC.AddObject(new FAVORITE_DOC
996
                    {
997
                        ID = shortGuid(),
998
                        PROJECT_NO = prjNo,
999
                        DOCUMENT_ID = documentItemID,
1000
                        GROUP_NO = groupNo,
1001
                        DOCUMENT_NO = docNo,
1002
                        MEMBER_USER_ID = userID,
1003
                        DESCRIPTION = VPDescription,
1004
                        CREATE_TIME = DateTime.Now,
1005
                        REVISION = rev,
1006
                        FLAG = (int)flag,
1007
                        PAGE_NO = SavePageNo,
1008
                    });
1009
                    entity.SaveChanges();
1010
                }
1011
                catch (Exception)
1012
                {
1013
                    return false;
1014
                }
1015

    
1016
                return true;
1017
            }
1018
        }
1019

    
1020
        //[OperationContract]
1021
        //public List<FAVORITE_DOC> GetFavoriteVP(string PrjNo, string userID, string sharepointItemID)
1022
        //{
1023
        //    using (KCOMEntities entity = new KCOMEntities(ConnectStringBuilder.KCOMConnectionString().ToString()))
1024
        //    {
1025

    
1026
        //        int flagString = Convert.ToInt32(IKCOM.FAVORITE_FLAG.Personal);                
1027
        //        List<FAVORITE_DOC> favoriteListSet = new List<FAVORITE_DOC>();
1028
        //        entity.FAVORITE_DOC.Where(data => data.PROJECT_NO == PrjNo && data.DOCUMENT_ID == sharepointItemID && data.FLAG !=
1029
        //            flagString).ToList().ForEach(data => favoriteListSet.Add(data));
1030
        //        entity.FAVORITE_DOC.Where(data => data.PROJECT_NO == PrjNo && data.MEMBER_USER_ID == userID).ToList().ForEach(data => favoriteListSet.Add(data));
1031
        //        favoriteListSet = favoriteListSet.Distinct().ToList();
1032
        //        return favoriteListSet;
1033
        //    }
1034
        //}
1035
        //[OperationContract]
1036
        //public bool EditFavoriteVP(string prjNo, string userID, int SavePageNo, string sharepointItemID, DateTime createTime, int state, string description)
1037
        //{
1038
        //    using (DeepViewEntities dc = new DeepViewEntities(ConnectStringBuilder.DeepViewConnectionString().ToString()))
1039
        //    {
1040
        //        List<FavoriteVP> favoriteSet = dc.FavoriteVP.Where(data => data.ProjectNo == prjNo && data.CreateUserID == userID
1041
        //            && data.PageNo == SavePageNo && data.CreateTime == createTime).ToList();
1042

    
1043
        //        try
1044
        //        {
1045

    
1046

    
1047
        //            if (favoriteSet.Count > 0)
1048
        //            {
1049
        //                var FavoriteVP_Instance = favoriteSet.First();
1050

    
1051
        //                FavoriteVP_Instance.Description = description;
1052
        //                FavoriteVP_Instance.Flag = state;
1053

    
1054
        //                dc.SaveChanges();
1055

    
1056
        //                return true;
1057
        //            }
1058
        //            else
1059
        //            {
1060
        //                return false;
1061
        //            }
1062
        //        }
1063
        //        catch (Exception)
1064
        //        {
1065
        //            return false;
1066
        //        }
1067
        //    }
1068
        //}
1069
        //[OperationContract]
1070
        //public bool DelFavoriteVP(string prjNo, string userID, int SavePageNo, string sharepointItemID, DateTime createTime)
1071
        //{
1072

    
1073
        //    using (DeepViewEntities dc = new DeepViewEntities(ConnectStringBuilder.DeepViewConnectionString().ToString()))
1074
        //    {
1075
        //        List<FavoriteVP> favoriteSet = dc.FavoriteVP.Where(data => data.ProjectNo == prjNo && data.CreateUserID == userID
1076
        //            && data.PageNo == SavePageNo && data.CreateTime == createTime).ToList();
1077

    
1078
        //        try
1079
        //        {
1080

    
1081

    
1082
        //            if (favoriteSet.Count > 0)
1083
        //            {
1084
        //                favoriteSet.ForEach(data => dc.FavoriteVP.DeleteObject(data));
1085
        //                dc.SaveChanges();
1086
        //                return true;
1087
        //            }
1088
        //            else
1089
        //            {
1090
        //                return false;
1091
        //            }
1092
        //        }
1093
        //        catch (Exception)
1094
        //        {
1095
        //            return false;
1096
        //        }
1097
        //    }
1098
        //}
1099
        #endregion
1100

    
1101
        [OperationContract]
1102
        public bool SaveMarkupData(MarkupInfoItem UserState,string project_no,string doc_id, string user_id, List<MARKUP_DATA> mlmarkup_data)
1103
        {
1104
            
1105
            string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1106
            using (CIEntities Entity = new CIEntities(sCIConnString))
1107
            {     
1108
                #region Docinfo 정보 가져오기
1109

    
1110
                string docinfoid_ = (from info in Entity.DOCINFO
1111
                                     where info.DOCUMENT_ID == doc_id
1112
                                     && info.PROJECT_NO == project_no
1113
                                     select info.ID
1114
                                     ).First().ToString();
1115
                #endregion
1116

    
1117
                #region Markup_Info 저장
1118

    
1119
                MARKUP_INFO markup_info = new MARKUP_INFO();
1120
                try
1121
                {
1122
                    markup_info = (from info in Entity.MARKUP_INFO
1123
                                   where info.ID == UserState.MarkupInfoID && info.USER_ID == user_id
1124
                                   select info).FirstOrDefault();
1125
                }
1126
                catch (Exception)
1127
                {
1128
                    markup_info = null;
1129
                }
1130

    
1131
                //markup_info가 없을 경우 생성
1132
                if (markup_info == null)
1133
                {
1134
                    //MarkupInfo 저장
1135
                    markup_info = new MARKUP_INFO
1136
                    {
1137
                        ID = UserState.MarkupInfoID,
1138
                        DOCINFO_ID = docinfoid_,
1139
                        USER_ID = user_id,
1140
                        CREATE_TIME = DateTime.Now,
1141
                        CONSOLIDATE = UserState.Consolidate,
1142
                        AVOID_CONSOLIDATE = UserState.AvoidConsolidate,
1143
                        PART_CONSOLIDATE = UserState.PartConsolidate,
1144
                        DESCRIPTION = UserState.Description,
1145
                        UPDATE_TIME = DateTime.Now
1146
                    };
1147
                    Entity.MARKUP_INFO.AddObject(markup_info);
1148
                }
1149
                //markup_info가 있을 경우 업데이트
1150
                else
1151
                {
1152
                    markup_info.UPDATE_TIME = DateTime.Now;
1153
                }
1154
                Entity.SaveChanges();
1155
                #endregion
1156

    
1157
                #region Markup_Info_Version 저장
1158

    
1159
                MARKUP_INFO_VERSION markup_info_version = new MARKUP_INFO_VERSION();
1160

    
1161
                try
1162
                {
1163
                    markup_info_version = (from info in Entity.MARKUP_INFO_VERSION
1164
                                           where info.MARKUPINFO_ID == markup_info.ID
1165
                                           select info).FirstOrDefault();
1166
                }
1167
                catch (Exception)
1168
                {
1169
                    markup_info_version = null;
1170
                }
1171

    
1172
                //markup_info_version 없을 경우 생성
1173
                if (markup_info_version == null)
1174
                {
1175
                    //MarkupInfo_version 저장
1176
                    markup_info_version = new MARKUP_INFO_VERSION()
1177
                    {
1178
                        ID = UserState.MarkupVersionID,
1179
                        MARKUPINFO_ID = markup_info.ID,
1180
                        CREATE_DATE = DateTime.Now
1181
                    };
1182
                    Entity.MARKUP_INFO_VERSION.AddObject(markup_info_version);
1183
                    Entity.SaveChanges();
1184
                }
1185
                #endregion
1186

    
1187
                
1188
                Entity.MARKUP_DATA.Where(data => data.MARKUPINFO_VERSION_ID == markup_info_version.ID).ToList().ForEach(item =>
1189
                {
1190
                    Entity.MARKUP_DATA.DeleteObject(item);
1191
                });
1192
                Entity.SaveChanges();
1193

    
1194
                try
1195
                {
1196
                    mlmarkup_data.ForEach(value =>
1197
                    {
1198
                        Entity.MARKUP_DATA.AddObject(new MARKUP_DATA
1199
                        {
1200
                            ID = value.ID,
1201
                            DATA = value.DATA,
1202
                            DATA_TYPE = value.DATA_TYPE,
1203
                            PAGENUMBER = value.PAGENUMBER,
1204
                            MARKUPINFO_VERSION_ID = markup_info_version.ID,
1205
                            SYMBOL_ID = value.SYMBOL_ID,
1206
                            //GROUP_ID = value.GROUP_ID
1207
                        });
1208
                    });
1209
                    Entity.SaveChanges();
1210
                }
1211
                catch (Exception)
1212
                {
1213
                    return false;
1214
                }
1215
            }
1216
            return true;
1217
        }
1218

    
1219
        [OperationContract]
1220
        public bool SavePageMarkupData(MarkupInfoItem UserState,int PageNo, string project_no, string doc_id, string user_id, List<MARKUP_DATA> mlmarkup_data)
1221
        {
1222

    
1223
            string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1224
            using (CIEntities Entity = new CIEntities(sCIConnString))
1225
            {
1226
                #region Docinfo 정보 가져오기
1227

    
1228
                string docinfoid_ = (from info in Entity.DOCINFO
1229
                                     where info.DOCUMENT_ID == doc_id
1230
                                     && info.PROJECT_NO == project_no
1231
                                     select info.ID
1232
                                     ).First().ToString();
1233
                #endregion
1234

    
1235
                #region Markup_Info 저장
1236

    
1237
                MARKUP_INFO markup_info = new MARKUP_INFO();
1238
                try
1239
                {
1240
                    markup_info = (from info in Entity.MARKUP_INFO
1241
                                   where info.ID == UserState.MarkupInfoID && info.USER_ID == user_id
1242
                                   select info).FirstOrDefault();
1243
                }
1244
                catch (Exception)
1245
                {
1246
                    markup_info = null;
1247
                }
1248

    
1249
                //markup_info가 없을 경우 생성
1250
                if (markup_info == null)
1251
                {
1252
                    //MarkupInfo 저장
1253
                    markup_info = new MARKUP_INFO
1254
                    {
1255
                        ID = UserState.MarkupInfoID,
1256
                        DOCINFO_ID = docinfoid_,
1257
                        USER_ID = user_id,
1258
                        CREATE_TIME = DateTime.Now,
1259
                        CONSOLIDATE = UserState.Consolidate,
1260
                        AVOID_CONSOLIDATE = UserState.AvoidConsolidate,
1261
                        PART_CONSOLIDATE = UserState.PartConsolidate,
1262
                        DESCRIPTION = UserState.Description,
1263
                        UPDATE_TIME = DateTime.Now
1264
                    };
1265
                    Entity.MARKUP_INFO.AddObject(markup_info);
1266
                }
1267
                //markup_info가 있을 경우 업데이트
1268
                else
1269
                {
1270
                    markup_info.UPDATE_TIME = DateTime.Now;
1271
                }
1272
                Entity.SaveChanges();
1273
                #endregion
1274

    
1275
                #region Markup_Info_Version 저장
1276

    
1277
                MARKUP_INFO_VERSION markup_info_version = new MARKUP_INFO_VERSION();
1278

    
1279
                try
1280
                {
1281
                    markup_info_version = (from info in Entity.MARKUP_INFO_VERSION
1282
                                           where info.MARKUPINFO_ID == markup_info.ID
1283
                                           select info).FirstOrDefault();
1284
                }
1285
                catch (Exception)
1286
                {
1287
                    markup_info_version = null;
1288
                }
1289

    
1290
                //markup_info_version 없을 경우 생성
1291
                if (markup_info_version == null)
1292
                {
1293
                    //MarkupInfo_version 저장
1294
                    markup_info_version = new MARKUP_INFO_VERSION()
1295
                    {
1296
                        ID = UserState.MarkupVersionID,
1297
                        MARKUPINFO_ID = markup_info.ID,
1298
                        CREATE_DATE = DateTime.Now
1299
                    };
1300
                    Entity.MARKUP_INFO_VERSION.AddObject(markup_info_version);
1301
                    Entity.SaveChanges();
1302
                }
1303
                #endregion
1304

    
1305

    
1306
                Entity.MARKUP_DATA.Where(data =>  data.PAGENUMBER == PageNo && data.MARKUPINFO_VERSION_ID == markup_info_version.ID).ToList().ForEach(item =>
1307
                {
1308
                    Entity.MARKUP_DATA.DeleteObject(item);
1309
                });
1310
                Entity.SaveChanges();
1311

    
1312
                try
1313
                {
1314
                    mlmarkup_data.ForEach(value =>
1315
                    {
1316
                        Entity.MARKUP_DATA.AddObject(new MARKUP_DATA
1317
                        {
1318
                            ID = value.ID,
1319
                            DATA = value.DATA,
1320
                            DATA_TYPE = value.DATA_TYPE,
1321
                            PAGENUMBER = value.PAGENUMBER,
1322
                            MARKUPINFO_VERSION_ID = markup_info_version.ID,
1323
                            SYMBOL_ID = value.SYMBOL_ID,
1324
                            //GROUP_ID = value.GROUP_ID
1325
                        });
1326
                    });
1327
                    Entity.SaveChanges();
1328
                }
1329
                catch (Exception)
1330
                {
1331
                    return false;
1332
                }
1333
            }
1334
            return true;
1335
        }
1336

    
1337
        //[OperationContract]
1338
        //public long AddMarkupDataGroup(MARKUP_DATA_GROUP mARKUP_DATA_GROUP, string ProjectNo)
1339
        //{
1340
        //    try
1341
        //    {
1342
        //        using (CIEntities Entity = new CIEntities(ConnectStringBuilder.ProjectCIConnectString(ProjectNo).ToString()))
1343
        //        {
1344
        //            Entity.AddToMARKUP_DATA_GROUP(mARKUP_DATA_GROUP);
1345
        //            //MARKUP_DATA_GROUP tt = Entity.MARKUP_DATA_GROUP.Where(info => info.ID == id).FirstOrDefault();
1346
        //            Entity.SaveChanges();
1347

    
1348
        //            return Entity.MARKUP_DATA_GROUP.ToList().LastOrDefault().ID;
1349
        //        }
1350
        //    }
1351
        //    catch (Exception)
1352
        //    {
1353
        //        return 0;
1354
        //    }
1355
        //}
1356
        //[OperationContract]
1357
        //public bool UpdateMarkupDataGroup(long Group_ID, string ProjectNo)
1358
        //{
1359
        //    try
1360
        //    {
1361
        //        using (CIEntities Entity = new CIEntities(ConnectStringBuilder.ProjectCIConnectString(ProjectNo).ToString()))
1362
        //        {
1363
        //            var UpdateItem = Entity.MARKUP_DATA_GROUP.Where(info => info.ID == Group_ID).FirstOrDefault();
1364
        //            UpdateItem.STATE = 1;
1365
        //            Entity.SaveChanges();
1366
        //        }
1367
        //    }
1368
        //    catch (Exception)
1369
        //    {
1370
        //        return false;
1371
        //    }
1372
        //    return true;
1373
        //}
1374
        [OperationContract]
1375
        public bool UpdateMarkupData(string CommentID, long Group_ID, string ProjectNo)
1376
        {
1377
            try
1378
            {
1379
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1380
                using (CIEntities Entity = new CIEntities(sCIConnString))
1381
                {
1382
                    var UpdateItem = Entity.MARKUP_DATA.Where(info => info.ID == CommentID).FirstOrDefault();
1383
                    //UpdateItem.GROUP_ID = Group_ID;
1384
                    Entity.SaveChanges();
1385
                }
1386
            }
1387
            catch (Exception)
1388
            {
1389
                return false;
1390
            }
1391
            return true;
1392
        }
1393

    
1394
        [OperationContract]
1395
        public bool SaveSymbol(SYMBOL_PRIVATE symbol_private)
1396
        {
1397
            try
1398
            {
1399
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
1400
                using (KCOMDataModel.DataModel.KCOMEntities uc = new KCOMDataModel.DataModel.KCOMEntities(sConnString))
1401
                {
1402
                    uc.AddToSYMBOL_PRIVATE(symbol_private);
1403
                    uc.SaveChanges();
1404
                }
1405
            }
1406
            catch(Exception)
1407
            {
1408
                return false;
1409
            }
1410
            return true;
1411
        }
1412
        [OperationContract]
1413
        public bool AddPublicSymbol(SYMBOL_PUBLIC symbol)
1414
        {
1415
            try
1416
            {
1417
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
1418
                using (KCOMDataModel.DataModel.KCOMEntities uc = new KCOMDataModel.DataModel.KCOMEntities(sConnString))
1419
                {
1420
                    uc.AddToSYMBOL_PUBLIC(symbol);
1421
                    uc.SaveChanges();
1422
                }
1423
            }
1424
            catch (Exception)
1425
            {
1426
                return false;
1427
            }
1428
            return true;
1429
        }
1430
        [OperationContract]
1431
        public bool DeleteSymbol(string symbol_id, int type)
1432
        {
1433
            try
1434
            {
1435
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
1436
                using (KCOMEntities Entity = new KCOMEntities(sConnString))
1437
                {
1438
                    if (type == 0)
1439
                    {
1440
                        string delItem_ID = symbol_id;
1441
                        var delitem = Entity.SYMBOL_PRIVATE.Where(data => data.ID == delItem_ID).FirstOrDefault();
1442
                        Entity.SYMBOL_PRIVATE.DeleteObject(delitem);
1443
                        Entity.SaveChanges();
1444
                    }
1445
                    else
1446
                    {
1447
                        string delItem_ID = symbol_id;
1448
                        var delitem = Entity.SYMBOL_PUBLIC.Where(data => data.ID == delItem_ID).FirstOrDefault();
1449
                        Entity.SYMBOL_PUBLIC.DeleteObject(delitem);
1450
                        Entity.SaveChanges();
1451
                    }
1452
                }
1453
            }
1454
            catch(Exception)
1455
            {
1456
                return false;
1457
            }
1458
            return true;
1459
        }
1460

    
1461
        [OperationContract]
1462
        public bool RenameSymbol(string symbol_id, string name, int type)
1463
        {
1464
            try
1465
            {
1466
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
1467
                using (KCOMEntities Entity = new KCOMEntities(sConnString))
1468
                {
1469
                    if (type == 0)
1470
                    {
1471
                        var UpdateItem = Entity.SYMBOL_PRIVATE.Where(info => info.ID == symbol_id).FirstOrDefault();
1472
                        UpdateItem.NAME = name;
1473
                        Entity.SaveChanges();
1474
                    }
1475
                    else
1476
                    {
1477
                        var UpdateItem = Entity.SYMBOL_PUBLIC.Where(info => info.ID == symbol_id).FirstOrDefault();
1478
                        UpdateItem.NAME = name;
1479
                        Entity.SaveChanges();
1480
                    }
1481
                }
1482
            }
1483
            catch (Exception)
1484
            {
1485
                return false;
1486
            }
1487
            return true;
1488
        }
1489

    
1490
        [OperationContract]
1491
        public bool AddCheckListHistory(string project_no, CHECK_LIST_HISTORY Check_History)
1492
        {
1493
            try
1494
            {
1495
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1496
                using (CIEntities Entity = new CIEntities(sCIConnString))
1497
                {
1498
                    Entity.CHECK_LIST_HISTORY.AddObject(Check_History);
1499
                    Entity.SaveChanges();  
1500
                }
1501
            }
1502
            catch (Exception)
1503
            {
1504
                return false;
1505
            }
1506
            return true;
1507
        }
1508
        [OperationContract]
1509
        public bool SaveCheckListHistory(string project_no, string rev, CHECK_LIST_HISTORY Check_History)
1510
        {
1511
            try
1512
            {
1513
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1514
                using (CIEntities Entity = new CIEntities(sCIConnString))
1515
                {
1516
                    var item = Entity.CHECK_LIST_HISTORY.Where(info => info.REVISION == rev).FirstOrDefault();
1517
                    item = Check_History;
1518
                    Entity.SaveChanges();
1519
                }
1520
            }
1521
            catch (Exception)
1522
            {
1523
                return false;
1524
            }
1525
            return true;
1526
        }
1527
        [OperationContract]
1528
        public bool SaveCheckList(string project_no, string _id, CHECK_LIST Check_value)
1529
        {
1530
            try
1531
            {
1532
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1533
                using (CIEntities Entity = new CIEntities(sCIConnString))
1534
                {
1535
                    var item = Entity.CHECK_LIST.Where(info => info.ID == _id).FirstOrDefault();
1536
                    item.TODOLIST = Check_value.TODOLIST;
1537
                    item.REMARK = Check_value.REMARK;
1538
                    item.STATUS = Check_value.STATUS;
1539
                    item.VENDOR = Check_value.VENDOR;
1540
                    item.REPLY = Check_value.REPLY;
1541
                    item.IMAGE_URL = Check_value.IMAGE_URL;
1542
                    item.IMAGE_ANCHOR = Check_value.IMAGE_ANCHOR;
1543
                    item.UPDATE_TIME = Check_value.UPDATE_TIME;
1544
                    if(Check_value.STATUS == "False")
1545
                    {
1546
                        item.STATUS_DESC_OPEN = Check_value.STATUS_DESC_OPEN;
1547
                    }
1548
                    else
1549
                    {
1550
                        item.STATUS_DESC_CLOSE = Check_value.STATUS_DESC_CLOSE;
1551
                    }                     
1552
                    Entity.SaveChanges();
1553
                }
1554
            }
1555
            catch (Exception)
1556
            {
1557
                return false;
1558
            }
1559
            return true;
1560
        }
1561
        [OperationContract]
1562
        public bool AddCheckList(string project_no, CHECK_LIST Check_value)
1563
        {
1564
            try
1565
            {
1566
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1567
                using (CIEntities Entity = new CIEntities(sCIConnString))
1568
                {
1569
                    Entity.CHECK_LIST.AddObject(Check_value);
1570
                    Entity.SaveChanges();
1571
                }
1572
            }
1573
            catch (Exception)
1574
            {
1575
                return false;
1576
            }
1577
            return true;
1578
        }
1579

    
1580
        [OperationContract]
1581
        public CHECK_LIST GetCheckList(string project_no, string _id)
1582
        {
1583
            CHECK_LIST Check_value = new CHECK_LIST();
1584
            try
1585
            {
1586
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1587
                using (CIEntities Entity = new CIEntities(sCIConnString))
1588
                {
1589
                    Check_value = Entity.CHECK_LIST.Where(info => info.ID == _id).FirstOrDefault();
1590
                }
1591
            }
1592
            catch (Exception)
1593
            {
1594
                return null;
1595
            }
1596
            return Check_value;
1597
        }
1598
        [OperationContract]
1599
        public List<CHECK_LIST> GetUserCheckList(string project_no, string user_id, string doc_no)
1600
        {
1601
            List<CHECK_LIST> list = new List<CHECK_LIST>();
1602
            try
1603
            {
1604
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1605
                using (CIEntities Entity = new CIEntities(sCIConnString))
1606
                {
1607
                    list = Entity.CHECK_LIST.Where(i => i.PROJECT_NO == project_no && i.DOCUMENT_NO == doc_no && i.USER_ID == user_id).OrderBy(p => p.CREATE_TIME).ToList();
1608
                }
1609
            }
1610
            catch (Exception)
1611
            {
1612
                return null;
1613
            }
1614
            return list;
1615
        }
1616
        [OperationContract]
1617
        public List<CHECK_LIST_HISTORY> GetCheckListHistory(string project_no, string _id)
1618
        {
1619
            List<CHECK_LIST_HISTORY> history = new List<CHECK_LIST_HISTORY>();
1620
            try
1621
            {
1622
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1623
                using (CIEntities Entity = new CIEntities(sCIConnString))
1624
                {
1625
                    history = Entity.CHECK_LIST_HISTORY.Where(data => data.CHECKLIST_ID == _id).ToList();
1626
                }
1627
            }
1628
            catch (Exception)
1629
            {
1630
                return null;
1631
            }
1632
            return history;
1633
        }
1634
        [OperationContract]
1635
        public CHECK_LIST_HISTORY GetCheckListHistoryFirstOrDefault(string project_no, string checklist_id, string rev)
1636
        {
1637
            CHECK_LIST_HISTORY Check_Item = new CHECK_LIST_HISTORY();
1638
            try
1639
            {
1640
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1641
                using (CIEntities Entity = new CIEntities(sCIConnString))
1642
                {   
1643
                    Check_Item = Entity.CHECK_LIST_HISTORY.Where(info => info.CHECKLIST_ID == checklist_id && info.REVISION == rev).FirstOrDefault();
1644
                }
1645
            }
1646
            catch (Exception)
1647
            {
1648
                return null;
1649
            }
1650
            return Check_Item;
1651
        }
1652
        [OperationContract]
1653
        public bool SavePageAngle(string project_no, List<DOCPAGE> _mldocpage)
1654
        {
1655
            try
1656
            {
1657
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1658
                using (CIEntities Entity = new CIEntities(sCIConnString))
1659
                {
1660
                    KCOMDataModel.DataModel.DOCPAGE _docpage = new KCOMDataModel.DataModel.DOCPAGE();
1661
                    _mldocpage.ForEach(data =>
1662
                    {
1663
                        _docpage = (from info in Entity.DOCPAGE
1664
                                    where info.ID == data.ID
1665
                                    select info).FirstOrDefault();
1666

    
1667
                        if (_docpage.PAGE_ANGLE != data.PAGE_ANGLE)
1668
                        {
1669
                            _docpage.PAGE_ANGLE = data.PAGE_ANGLE;
1670
                        }
1671
                    });
1672

    
1673
                    Entity.SaveChanges();
1674
                }
1675
            }
1676
            catch (Exception)
1677
            {
1678
                return false;
1679
            }
1680
            return true;
1681
        }
1682

    
1683
        [OperationContract]
1684
        public MARKUP_INFO GetMarkupInfo(string project_no, string _id)
1685
        {
1686
            MARKUP_INFO markupInfo = new MARKUP_INFO();
1687

    
1688
            try
1689
            {
1690
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1691
                using (CIEntities Entity = new CIEntities(sCIConnString))
1692
                {
1693
                    markupInfo = Entity.MARKUP_INFO.Where(entity => entity.DOCINFO_ID == _id).OrderByDescending(i => i.CONSOLIDATE).OrderByDescending(j => j.CREATE_TIME).FirstOrDefault();
1694
                }
1695
            }
1696
            catch (Exception)
1697
            {
1698
                return null;
1699
            }
1700
            return markupInfo;
1701
        }
1702

    
1703
        [OperationContract]
1704
        public List<string> GetMarkupDataListperPage(string project_no, string _markupinfoid, int _pageNo)
1705
        {
1706
            List<string> markupdata = new List<string>();
1707
            MARKUP_INFO_VERSION markup_info_version = new MARKUP_INFO_VERSION();
1708
            try
1709
            {
1710
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1711
                using (CIEntities Entity = new CIEntities(sCIConnString))
1712
                {
1713
                    markup_info_version = (from version in Entity.MARKUP_INFO_VERSION
1714
                                           where version.MARKUPINFO_ID == _markupinfoid
1715
                                           orderby version.CREATE_DATE descending
1716
                                           select version).First();
1717
                    markupdata = (from data in Entity.MARKUP_DATA
1718
                                  where data.MARKUPINFO_VERSION_ID == markup_info_version.ID && data.PAGENUMBER == _pageNo
1719
                                  select data.DATA).ToList();
1720
                }
1721
            }
1722
            catch (Exception)
1723
            {
1724
                return null;
1725
            }
1726
            return markupdata;
1727
        }
1728

    
1729
        [OperationContract]
1730
        public bool AddMarkupInfo(string project_no, MARKUP_INFO value)
1731
        {
1732
            try
1733
            {
1734
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1735
                using (CIEntities Entity = new CIEntities(sCIConnString))
1736
                {
1737
                    Entity.MARKUP_INFO.AddObject(value);
1738
                    Entity.SaveChanges();
1739
                }
1740
            }
1741
            catch (Exception)
1742
            {
1743
                return false;
1744
            }
1745
            return true;
1746
        }
1747

    
1748
        [OperationContract]
1749
        public bool AddMarkupInfoVersion(string project_no, MARKUP_INFO_VERSION value)
1750
        {
1751
            try
1752
            {
1753
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1754
                using (CIEntities Entity = new CIEntities(sCIConnString))
1755
                {
1756
                    Entity.MARKUP_INFO_VERSION.AddObject(value);
1757
                    Entity.SaveChanges();
1758
                }
1759
            }
1760
            catch (Exception)
1761
            {
1762
                return false;
1763
            }
1764
            return true;
1765
        }
1766

    
1767
        [OperationContract]
1768
        public bool AddMarkupData(string project_no, MARKUP_DATA value)
1769
        {
1770
            try
1771
            {
1772
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1773
                using (CIEntities Entity = new CIEntities(sCIConnString))
1774
                {
1775
                    Entity.MARKUP_DATA.AddObject(value);
1776
                    Entity.SaveChanges();
1777
                }
1778
            }
1779
            catch (Exception)
1780
            {
1781
                return false;
1782
            }
1783
            return true;
1784
        }
1785

    
1786
        [OperationContract]
1787
        public bool AvoidMarkupInfo(string project_no, string _doc_id)
1788
        {
1789
            try
1790
            {
1791
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1792
                using (CIEntities Entity = new CIEntities(sCIConnString))
1793
                {
1794
                    var item = Entity.MARKUP_INFO.Where(entity => entity.DOCINFO_ID == _doc_id).OrderByDescending(i => i.CONSOLIDATE).OrderByDescending(j => j.CREATE_TIME).FirstOrDefault();
1795
                    item.AVOID_CONSOLIDATE = 1;
1796
                    Entity.SaveChanges();
1797
                }
1798
            }
1799
            catch (Exception)
1800
            {
1801
                return false;
1802
            }
1803
            return true;
1804
        }
1805

    
1806
        [OperationContract]
1807
        public bool SaveMarkupInfo(string project_no, string _id, MARKUP_INFO value)
1808
        {
1809
            try
1810
            {
1811
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1812
                using (CIEntities Entity = new CIEntities(sCIConnString))
1813
                {
1814
                    var item = Entity.MARKUP_INFO.Where(info => info.ID == _id).FirstOrDefault();
1815
                    item = value;                    
1816
                    Entity.SaveChanges();
1817
                }
1818
            }
1819
            catch (Exception)
1820
            {
1821
                return false;
1822
            }
1823
            return true;
1824
        }
1825
        [OperationContract]
1826
        public List<MARKUP_DATA> GetMarkupDataList(string project_no, string _versionid)
1827
        {
1828
            List<MARKUP_DATA> mlresult = new List<MARKUP_DATA>();
1829

    
1830
            try
1831
            {
1832
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1833
                using (CIEntities Entity = new CIEntities(sCIConnString))
1834
                {
1835
                    mlresult = Entity.MARKUP_DATA.Where(data => data.MARKUPINFO_VERSION_ID == _versionid).ToList();
1836
                }
1837
            }
1838
            catch (Exception)
1839
            {
1840
                return null;
1841
            }
1842
            return mlresult;
1843
        }
1844

    
1845
        [OperationContract]
1846
        public bool Consolidate(string project_no, string _user_id, string _doc_id, List<MarkupInfoItem> markupInfoItems)
1847
        {
1848
            try
1849
            {
1850
                List<KCOMDataModel.DataModel.MARKUP_DATA> instanceDataSet = new List<KCOMDataModel.DataModel.MARKUP_DATA>();
1851
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1852
                using (CIEntities Entity = new CIEntities(sCIConnString))
1853
                {
1854
                    var markupInfo = Entity.MARKUP_INFO.Where(entity => entity.DOCINFO_ID == _doc_id && entity.CONSOLIDATE == 1).OrderByDescending(j => j.CREATE_TIME).FirstOrDefault();
1855
                    if (markupInfo != null)
1856
                    {
1857
                        markupInfo.AVOID_CONSOLIDATE = 1;
1858
                    }
1859

    
1860
                    foreach (MarkupInfoItem item in markupInfoItems)
1861
                    {
1862
                        Entity.MARKUP_DATA.Where(data => data.MARKUPINFO_VERSION_ID == item.MarkupVersionID).ToList().ForEach(d =>
1863
                        {
1864
                            instanceDataSet.Add(d);
1865
                        });
1866
                    }
1867

    
1868
                    KCOMDataModel.DataModel.MARKUP_INFO info = new KCOMDataModel.DataModel.MARKUP_INFO();
1869
                    info.ID = shortGuid();
1870
                    info.CONSOLIDATE = 1;
1871
                    info.CREATE_TIME = DateTime.Now;
1872
                    info.DOCINFO_ID = _doc_id;
1873
                    info.UPDATE_TIME = DateTime.Now;
1874
                    info.USER_ID = _user_id;
1875
                    info.AVOID_CONSOLIDATE = 0;
1876

    
1877
                    Entity.MARKUP_INFO.AddObject(info);
1878
                    Entity.SaveChanges();
1879

    
1880

    
1881
                    KCOMDataModel.DataModel.MARKUP_INFO_VERSION info2 = new KCOMDataModel.DataModel.MARKUP_INFO_VERSION
1882
                    {
1883
                        ID = shortGuid(),
1884
                        CREATE_DATE = DateTime.Now,
1885
                        MARKUP_INFO = info,
1886
                    };
1887
                    Entity.SaveChanges();
1888

    
1889
                    foreach (var item in instanceDataSet)
1890
                    {
1891
                        Entity.MARKUP_DATA.AddObject(new KCOMDataModel.DataModel.MARKUP_DATA
1892
                        {
1893
                            ID = shortGuid(),
1894
                            DATA = item.DATA,
1895
                            DATA_TYPE = item.DATA_TYPE,
1896
                            PAGENUMBER = item.PAGENUMBER,
1897
                            MARKUP_INFO_VERSION = info2,
1898
                            SYMBOL_ID = item.SYMBOL_ID,
1899
                            //GROUP_ID = item.GROUP_ID
1900
                        });
1901
                    }
1902
                    Entity.SaveChanges();
1903

    
1904

    
1905
                }
1906
            }
1907
            catch (Exception)
1908
            {
1909
                return false;
1910
            }
1911
            return true;
1912
        }
1913

    
1914

    
1915
        [OperationContract]
1916
        public FinalPDFResult ConsolidateMergedPDF(string project_no, string _user_id, string _doc_id, List<MarkupInfoItem> markupInfoItems, string ProjectNo, string DocInfoID, string CreateUserID)
1917
        {
1918
            bool consolidate = false;
1919
            try
1920
            {
1921
                List<KCOMDataModel.DataModel.MARKUP_DATA> instanceDataSet = new List<KCOMDataModel.DataModel.MARKUP_DATA>();
1922
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1923
                using (CIEntities Entity = new CIEntities(sCIConnString))
1924
                {
1925
                    var markupInfo = Entity.MARKUP_INFO.Where(entity => entity.DOCINFO_ID == _doc_id).OrderByDescending(i => i.CONSOLIDATE).OrderByDescending(j => j.CREATE_TIME).FirstOrDefault();
1926
                    if (markupInfo.CONSOLIDATE == 1)
1927
                    {
1928
                        markupInfo.AVOID_CONSOLIDATE = 1;
1929
                    }
1930

    
1931
                    foreach (MarkupInfoItem item in markupInfoItems)
1932
                    {
1933
                        Entity.MARKUP_DATA.Where(data => data.MARKUPINFO_VERSION_ID == item.MarkupVersionID).ToList().ForEach(d =>
1934
                        {
1935
                            instanceDataSet.Add(d);
1936
                        });
1937
                    }
1938

    
1939
                    KCOMDataModel.DataModel.MARKUP_INFO info = new KCOMDataModel.DataModel.MARKUP_INFO();
1940
                    info.ID = shortGuid();
1941
                    info.CONSOLIDATE = 1;
1942
                    info.CREATE_TIME = DateTime.Now;
1943
                    info.DOCINFO_ID = _doc_id;
1944
                    info.UPDATE_TIME = DateTime.Now;
1945
                    info.USER_ID = _user_id;
1946
                    info.AVOID_CONSOLIDATE = 0;
1947

    
1948
                    Entity.MARKUP_INFO.AddObject(info);
1949
                    Entity.SaveChanges();
1950

    
1951

    
1952
                    KCOMDataModel.DataModel.MARKUP_INFO_VERSION info2 = new KCOMDataModel.DataModel.MARKUP_INFO_VERSION
1953
                    {
1954
                        ID = shortGuid(),
1955
                        CREATE_DATE = DateTime.Now,
1956
                        MARKUP_INFO = info,
1957
                    };
1958
                    Entity.SaveChanges();
1959

    
1960
                    foreach (var item in instanceDataSet)
1961
                    {
1962
                        Entity.MARKUP_DATA.AddObject(new KCOMDataModel.DataModel.MARKUP_DATA
1963
                        {
1964
                            ID = shortGuid(),
1965
                            DATA = item.DATA,
1966
                            DATA_TYPE = item.DATA_TYPE,
1967
                            PAGENUMBER = item.PAGENUMBER,
1968
                            MARKUP_INFO_VERSION = info2,
1969
                            SYMBOL_ID = item.SYMBOL_ID,
1970
                            //GROUP_ID = item.GROUP_ID
1971
                        });
1972
                    }
1973
                    Entity.SaveChanges();
1974

    
1975

    
1976
                }
1977
                consolidate = true;
1978
            }
1979
            catch (Exception)
1980
            {
1981
                consolidate = false;
1982
            }
1983
            FinalPDFResult _result = new FinalPDFResult();
1984
            if (consolidate == true)
1985
            {
1986
                RemFinalPDFObject remObj = null;
1987
                try
1988
                {
1989
                    string _finalID = shortGuid();
1990
                    int _DocTotalPages = -1;
1991
                    string docItemId;
1992

    
1993
                    string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
1994
                    using (CIEntities _ci = new CIEntities(sCIConnString))
1995
                    {
1996
                        var _doc = _ci.DOCINFO.Where(info => info.ID == DocInfoID);
1997

    
1998
                        if (_doc.Count() > 0)
1999
                        {
2000
                            _DocTotalPages = _doc.First().PAGE_COUNT;
2001
                            docItemId = _doc.First().DOCUMENT_ID;
2002
                        }
2003
                        else
2004
                        {
2005
                            _result.Status = FinalStatus.Error;
2006
                            _result.Exception = "페이지 정보를 가져올 수 없습니다.";
2007
                            return _result;
2008
                        }
2009
                    }
2010

    
2011
                    var Items = GetMarkupInfoItems(ProjectNo, DocInfoID);
2012
                    if (_DocTotalPages > 0)
2013
                    {
2014
                        var item2 = Items.Cast<MarkupInfoItem>().Where(d => d.Consolidate == 1 && d.AvoidConsolidate == 0).FirstOrDefault();
2015
                        FINAL_PDF fm = new FINAL_PDF()
2016
                        {
2017
                            ID = _finalID,
2018
                            PROJECT_NO = ProjectNo,
2019
                            DOCINFO_ID = DocInfoID,
2020
                            DOCUMENT_ID = docItemId,
2021
                            MARKUPINFO_ID = item2.MarkupInfoID,
2022
                            CREATE_USER_ID = CreateUserID,
2023
                            TOTAL_PAGE = _DocTotalPages,
2024
                            CREATE_DATETIME = DateTime.Now,
2025
                            STATUS = (int)IFinalPDF.FinalStatus.Insert
2026
                        };
2027

    
2028
                        string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2029
                        using (KCOMEntities _entity = new KCOMEntities(sConnString))
2030
                        {
2031
                            _entity.AddToFINAL_PDF(fm);
2032
                            _entity.SaveChanges(System.Data.Objects.SaveOptions.AcceptAllChangesAfterSave);
2033
                        };
2034

    
2035
                        System.Runtime.Remoting.Channels.IChannel _ch = System.Runtime.Remoting.Channels.ChannelServices.GetChannel("tcp");
2036
                        if (_ch == null)
2037
                        {
2038
                            chan = new TcpChannel();
2039
                            _ChanID = chan.ChannelName;
2040
                            System.Runtime.Remoting.Channels.ChannelServices.RegisterChannel(chan, false);
2041
                            // Create an instance of the remote object
2042

    
2043
                            using (KCOMEntities ec = new KCOMEntities(sConnString))
2044
                            {
2045

    
2046
                                //remObj = (RemFinalPDFObject)Activator.GetObject(typeof(RemFinalPDFObject),
2047
                                //                          "tcp://localhost:9092/remFinalPDF");
2048
                                remObj = (RemFinalPDFObject)Activator.GetObject(typeof(RemFinalPDFObject),
2049
                                                          //"tcp://192.168.0.67:9092/remFinalPDF");
2050
                                                          "tcp://192.168.0.67:9092/remFinalPDF");
2051
                            }
2052

    
2053
                            //"tcp://localhost:8080/remFinalPDF");
2054

    
2055
                            _result = remObj.SetFinalPDF(ProjectNo, _finalID);
2056
                            _result.FinalID = _finalID;
2057
                            _result.Status = FinalStatus.Success;
2058

    
2059
                            //MarkupToPDF.MarkupToPDF fa = new MarkupToPDF.MarkupToPDF();
2060
                            //fa.MakeFinalPDF(fm);
2061
                        }
2062
                        else
2063
                        {
2064
                            _ChanID = _ch.ChannelName;
2065
                        }
2066
                    }
2067
                }
2068
                catch (Exception ex)
2069
                {
2070
                    _result.Status = FinalStatus.Error;
2071

    
2072
                    if (ex.GetType() == typeof(System.Net.Sockets.SocketException))
2073
                        _result.Exception = "Final Server Not Connection";
2074
                }
2075
                finally
2076
                {
2077
                    remObj = null;
2078
                    if (System.Runtime.Remoting.Channels.ChannelServices.GetChannel("tcp") != null)
2079
                        System.Runtime.Remoting.Channels.ChannelServices.UnregisterChannel(chan);
2080

    
2081
                    GC.Collect(2);
2082
                }
2083
            }
2084
            return _result;
2085
        }
2086
        [OperationContract]
2087
        public bool TeamConsolidate(string project_no, string _user_id, string _doc_id, List<MarkupInfoItem> markupInfoItems)
2088
        {
2089
            try
2090
            {
2091
                List<KCOMDataModel.DataModel.MARKUP_DATA> instanceDataSet = new List<KCOMDataModel.DataModel.MARKUP_DATA>();
2092
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2093
                using (CIEntities Entity = new CIEntities(sCIConnString))
2094
                {
2095
                    string user_dept = Entity.MEMBER.Where(m => m.ID == _user_id).FirstOrDefault().DEPARTMENT;
2096
                    var markupInfos = Entity.MARKUP_INFO.Where(entity => entity.DOCINFO_ID == _doc_id
2097
                    && entity.PART_CONSOLIDATE == 1
2098
                    ).OrderByDescending(j => j.CREATE_TIME).ToList();
2099
                    foreach (var markupinfo in markupInfos)
2100
                    {
2101
                        string markupdept = Entity.MEMBER.Where(m => m.ID == markupinfo.USER_ID).FirstOrDefault().DEPARTMENT;
2102
                        if (user_dept == markupdept)
2103
                        {
2104
                            markupinfo.AVOID_CONSOLIDATE = 1;
2105
                        }
2106
                    }
2107

    
2108
                    foreach (MarkupInfoItem item in markupInfoItems)
2109
                    {
2110
                        Entity.MARKUP_DATA.Where(data => data.MARKUPINFO_VERSION_ID == item.MarkupVersionID).ToList().ForEach(d =>
2111
                        {
2112
                            instanceDataSet.Add(d);
2113
                        });
2114
                    }
2115

    
2116
                    KCOMDataModel.DataModel.MARKUP_INFO info = new KCOMDataModel.DataModel.MARKUP_INFO();
2117
                    info.ID = shortGuid();
2118
                    info.PART_CONSOLIDATE = 1;
2119
                    info.CREATE_TIME = DateTime.Now;
2120
                    info.DOCINFO_ID = _doc_id;
2121
                    info.UPDATE_TIME = DateTime.Now;
2122
                    info.USER_ID = _user_id;
2123
                    info.AVOID_CONSOLIDATE = 0;
2124

    
2125
                    Entity.MARKUP_INFO.AddObject(info);
2126
                    Entity.SaveChanges();
2127

    
2128

    
2129
                    KCOMDataModel.DataModel.MARKUP_INFO_VERSION info2 = new KCOMDataModel.DataModel.MARKUP_INFO_VERSION
2130
                    {
2131
                        ID = shortGuid(),
2132
                        CREATE_DATE = DateTime.Now,
2133
                        MARKUP_INFO = info,
2134
                    };
2135
                    Entity.SaveChanges();
2136

    
2137
                    foreach (var item in instanceDataSet)
2138
                    {
2139
                        Entity.MARKUP_DATA.AddObject(new KCOMDataModel.DataModel.MARKUP_DATA
2140
                        {
2141
                            ID = shortGuid(),
2142
                            DATA = item.DATA,
2143
                            DATA_TYPE = item.DATA_TYPE,
2144
                            PAGENUMBER = item.PAGENUMBER,
2145
                            MARKUP_INFO_VERSION = info2,
2146
                            SYMBOL_ID = item.SYMBOL_ID,
2147
                            //GROUP_ID = item.GROUP_ID
2148
                        });
2149
                    }
2150
                    Entity.SaveChanges();
2151

    
2152

    
2153
                }
2154
            }
2155
            catch (Exception)
2156
            {
2157
                return false;
2158
            }
2159
            return true;
2160
        }
2161

    
2162
        [OperationContract]
2163
        [ServiceKnownType(typeof(MEMBER))]
2164
        public MEMBER GetMember(string project_no, string user_id)
2165
        {
2166
            MEMBER rstmember = null;
2167
            try
2168
            {
2169
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2170
                using (CIEntities Entity = new CIEntities(sCIConnString))
2171
                {
2172
                    string query = "SELECT members.ID,members.NAME,members.DEPARTMENT FROM CIEntities.MEMBER as members where members.ID = @userId";
2173

    
2174
                    var param = new[] { new System.Data.Objects.ObjectParameter("userId", user_id) };
2175

    
2176
                    System.Data.Objects.ObjectQuery<System.Data.Common.DbDataRecord> memberQuery
2177
                                  = Entity.CreateQuery<System.Data.Common.DbDataRecord>(query, param);
2178

    
2179
                    if (memberQuery.Count() > 0)
2180
                    {
2181
                        rstmember = new MEMBER();
2182

    
2183
                        string userName = memberQuery.First()["NAME"]?.ToString().Trim();
2184
                        string ID = memberQuery.First()["ID"]?.ToString().Trim();
2185
                        string depatment = memberQuery.First()["DEPARTMENT"]?.ToString().Trim();
2186

    
2187
                        rstmember.NAME = userName;
2188
                        rstmember.ID = ID;
2189
                        rstmember.DEPARTMENT = depatment;
2190
                    }
2191
                }
2192
            }
2193
            catch (Exception ex)
2194
            {
2195
                return null;
2196
            }
2197
            return rstmember;
2198
        }
2199

    
2200
        [WebMethod]
2201
        [OperationContract]
2202
        public List<SYMBOL_PRIVATE> GetSymbolList(string user_id)
2203
        {
2204
            List<SYMBOL_PRIVATE> Custom_List = new List<SYMBOL_PRIVATE>();
2205
            try
2206
            {
2207
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2208
                using (KCOMEntities Entity = new KCOMEntities(sConnString))
2209
                {
2210
                    Custom_List = Entity.SYMBOL_PRIVATE.Where(data => data.MEMBER_USER_ID == user_id).ToList();
2211
                }
2212
            }
2213
            catch (Exception ex)
2214
            {
2215
                return null;
2216
            }
2217
            return Custom_List;
2218
        }
2219
        [OperationContract]
2220
        public List<string> GetPublicSymbolDeptList()
2221
        {
2222
            List<string> Custom_List = new List<string>();
2223
            try
2224
            {
2225
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2226
                using (KCOMEntities Entity = new KCOMEntities(sConnString))
2227
                {
2228
                    Custom_List = Entity.SYMBOL_PUBLIC.Select(data => data.DEPARTMENT).Distinct().ToList();
2229
                }
2230
            }
2231
            catch (Exception)
2232
            {
2233
                return null;
2234
            }
2235
            return Custom_List;
2236
        }
2237
        [OperationContract]
2238
        public List<SYMBOL_PUBLIC> GetPublicSymbolList(string dept)
2239
        {
2240
            List<SYMBOL_PUBLIC> Custom_List = new List<SYMBOL_PUBLIC>();
2241
            try
2242
            {
2243
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2244
                using (KCOMEntities Entity = new KCOMEntities(sConnString))
2245
                {
2246
                    if(!string.IsNullOrEmpty(dept))
2247
                    {
2248
                        Custom_List = Entity.SYMBOL_PUBLIC.Where(data => data.DEPARTMENT == dept).ToList();
2249
                    }
2250
                    else
2251
                    {
2252
                        Custom_List = Entity.SYMBOL_PUBLIC.ToList();
2253
                    }
2254
                    
2255
                }
2256
            }
2257
            catch (Exception)
2258
            {
2259
                return null;
2260
            }
2261
            return Custom_List;
2262
        }
2263

    
2264
        /// <summary>
2265
        /// 
2266
        /// </summary>
2267
        /// <param name="id">symbol id</param>
2268
        /// <param name="type"> 0 : PRIVATE, 1 : PUBLIC</param>
2269
        /// <returns></returns>
2270
        [OperationContract]
2271
        public string GetSymbolData(string id, int type)
2272
        {
2273
            string result;
2274
            try
2275
            {
2276
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2277
                using (KCOMEntities Entity = new KCOMEntities(sConnString))
2278
                {
2279
                    if(type == 0)
2280
                    {
2281
                        result = Entity.SYMBOL_PRIVATE.Where(data => data.ID == id).FirstOrDefault().DATA;
2282
                    }
2283
                    else
2284
                    {
2285
                        result = Entity.SYMBOL_PUBLIC.Where(data => data.ID == id).FirstOrDefault().DATA;
2286
                    }
2287
                }
2288
            }
2289
            catch (Exception)
2290
            {
2291
                return null;
2292
            }
2293
            return result;
2294
        }
2295
        [OperationContract]
2296
        public string GetSymbolImageURL(string id, int type)
2297
        {
2298
            string result;
2299
            try
2300
            {
2301
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2302
                using (KCOMEntities Entity = new KCOMEntities(sConnString))
2303
                {
2304
                    if (type == 0)
2305
                    {
2306
                        result = Entity.SYMBOL_PRIVATE.Where(data => data.ID == id).FirstOrDefault().IMAGE_URL;
2307
                    }
2308
                    else
2309
                    {
2310
                        result = Entity.SYMBOL_PUBLIC.Where(data => data.ID == id).FirstOrDefault().IMAGE_URL;
2311
                    }
2312
                }
2313
            }
2314
            catch (Exception)
2315
            {
2316
                return null;
2317
            }
2318
            return result;
2319
        }
2320
        [OperationContract]
2321
        public string GetSignData(string project_no, string user_id)
2322
        {
2323
            string result = null;
2324
            try
2325
            {
2326
                string ifsign = getEnsembleSign(user_id);
2327
                if (string.IsNullOrEmpty(ifsign))
2328
                {
2329
                    string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2330
                    var ModelWFConnectionString = sCIConnString;
2331
                    if (null != ModelWFConnectionString)
2332
                    {
2333
                        using (CIEntities entity = new CIEntities(ModelWFConnectionString))
2334
                        {
2335
                            var _sign = entity.SIGN_INFO.Where(sin => sin.MEMBER_USER_ID == user_id);
2336
                            if (_sign.Count() > 0)
2337
                            {
2338
                                result = _sign.First().SIGN_STR;
2339
                            }
2340
                            else
2341
                            {
2342
                                return null;
2343
                            }
2344
                        }
2345
                    }
2346
                }
2347
                else
2348
                {
2349
                    result = ifsign;
2350
                }
2351

    
2352
            }
2353
            catch (Exception)
2354
            {
2355
                return null;
2356
            }
2357
            return result;
2358
        }
2359

    
2360
        [OperationContract]        
2361
        public string GetProjectName(string project_no)
2362
        {
2363
            string result = null;
2364

    
2365
            try
2366
            {
2367
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2368
                using (KCOMDataModel.DataModel.KCOMEntities Entity = new KCOMDataModel.DataModel.KCOMEntities(sConnString))
2369
                {
2370
                    result = Entity.RUN_PROJECTS.Where(i => i.PROJECT_NO == project_no).FirstOrDefault().PROJECT_NAME.ToString();
2371
                }
2372
            }
2373
            catch (Exception)
2374
            {
2375
                return null;
2376
            }
2377
            return result;
2378
        }
2379

    
2380
        [OperationContract]
2381
        public List<DOCUMENT_ITEM> GetPreRevSelect(string project_no, string doc_no, string current_rev)
2382
        {
2383
            List<DOCUMENT_ITEM> result = new List<DOCUMENT_ITEM>();
2384
            
2385
            try
2386
            {
2387
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2388
                using (CIEntities Entity = new CIEntities(sCIConnString))
2389
                {
2390
                    result = Entity.DOCUMENT_ITEM.Where(i => i.PROJECT_NO == project_no
2391
                    && i.DOCUMENT_NO == doc_no
2392
                    && i.REVISION != current_rev).OrderByDescending(i => i.GROUP_NO).ToList();
2393
                }
2394
            }
2395
            catch (Exception)
2396
            {
2397
                return null;
2398
            }
2399
            return result;
2400
        }
2401

    
2402
        [OperationContract]
2403
        public DOCINFO GetDocInfoOneSelect(string project_no, string doc_id)
2404
        {
2405
            DOCINFO docinfo = null;
2406

    
2407
            try
2408
            {
2409
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2410
                using (CIEntities Entity = new CIEntities(sCIConnString))
2411
                {
2412
                    docinfo = (from info in Entity.DOCINFO
2413
                              where info.DOCUMENT_ID == doc_id
2414
                              && info.PROJECT_NO == project_no
2415
                              select info).First();
2416
                }
2417
            }
2418
            catch (Exception)
2419
            {
2420
                return null;
2421
            }
2422
            return docinfo;
2423
        }
2424

    
2425
        [OperationContract]
2426
        public List<MarkupInfoItem> GetPrintDocItemList(string project_no, string doc_id, List<MarkupInfoItem> _markupInfoList)
2427
        {
2428
            MarkupInfoItem _result = null;
2429
            List<MarkupInfoItem> markupinfo = new List<MarkupInfoItem>();
2430
            try
2431
            {
2432
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2433
                using (CIEntities Entity = new CIEntities(sCIConnString))
2434
                {
2435
                    var docitem = (from info in Entity.DOCINFO
2436
                               where info.DOCUMENT_ID == doc_id
2437
                               && info.PROJECT_NO == project_no
2438
                               select info).First();
2439

    
2440
                    foreach (MARKUP_INFO markinfo in docitem.MARKUP_INFO)
2441
                    {
2442
                        var member = (from mem in Entity.MEMBER
2443
                                     where mem.ID == markinfo.USER_ID
2444
                                     select mem).First();
2445
                        string displaycolor = null;
2446
                        try
2447
                        {
2448
                            displaycolor = _markupInfoList.Where(info => info.MarkupInfoID == markinfo.ID).First().DisplayColor;
2449
                        }
2450
                        catch(Exception)
2451
                        {
2452
                            displaycolor = "#FFFFFF";
2453
                        }
2454
                        
2455
                        _result = new MarkupInfoItem
2456
                        {
2457
                            MarkupInfoID = markinfo.ID,
2458
                            Consolidate = markinfo.CONSOLIDATE,
2459
                            CreateTime = markinfo.UPDATE_TIME.HasValue ? markinfo.UPDATE_TIME.Value : markinfo.CREATE_TIME,
2460
                            DisplayColor = displaycolor,
2461
                            UserID = markinfo.USER_ID,
2462
                            UserName = member.NAME,
2463
                            Depatment = member.DEPARTMENT,
2464
                        };
2465

    
2466
                        _result.MarkupList = new List<IKCOM.MarkupItem>();
2467
                        var markup_Version = markinfo.MARKUP_INFO_VERSION.OrderByDescending(p => p.CREATE_DATE).First();
2468

    
2469
                        foreach (MARKUP_DATA markdata in markup_Version.MARKUP_DATA)
2470
                        {
2471
                            MarkupItem markitem = new MarkupItem()
2472
                            {
2473
                                ID = markdata.ID,
2474
                                PageNumber = markdata.PAGENUMBER,
2475
                            };
2476
                            _result.MarkupList.Add(markitem);
2477
                        }
2478

    
2479
                        _result.PageCount = _result.MarkupList.GroupBy(i => i.PageNumber).Count();
2480

    
2481
                        markupinfo.Add(_result);
2482
                    }
2483
                }
2484
            }
2485
            catch (Exception)
2486
            {
2487
                return null;
2488
            }
2489
            return markupinfo;
2490
        }
2491

    
2492
        [OperationContract]
2493
        public bool AddMessage(string project_no, TALK value)
2494
        {
2495
            try
2496
            {
2497
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2498
                using (CIEntities entity = new CIEntities(sCIConnString))
2499
                {                    
2500
                    entity.TALK.AddObject(value);
2501
                    entity.SaveChanges();
2502
                }
2503
            }
2504
            catch (Exception)
2505
            {
2506
                return false;
2507
            }
2508
            return true;
2509
        }
2510

    
2511
        [OperationContract]
2512
        public List<TALK> GetMessage(string project_no, string doc_id)
2513
        {
2514
            List<TALK> result = new List<TALK>();
2515
            try
2516
            {
2517
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2518
                using (CIEntities entity = new CIEntities(sCIConnString))
2519
                {
2520
                    result = entity.TALK.Where(data => data.DOCUMENT_ID == doc_id).ToList();                        
2521
                }
2522
            }
2523
            catch (Exception ex)
2524
            {
2525
                return result;
2526
            }
2527
            return result;
2528
        }
2529

    
2530

    
2531
        #region Legacy System I/F
2532
        /// <summary>
2533
        /// Ensemble+ Sign Data Return
2534
        /// </summary>
2535
        /// <param name="user_id"></param>
2536
        /// <returns></returns>
2537
        private string getEnsembleSign(string user_id)
2538
        {
2539
            string result = null;
2540
            string soapurl = string.Empty;
2541

    
2542
            try
2543
            {
2544
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2545
                using (KCOMEntities Entity = new KCOMEntities(sConnString))
2546
                {
2547
                    var item = Entity.PROPERTIES.Where(d => d.TYPE == "UpLoadServiceUrl").FirstOrDefault();
2548

    
2549
                    if (item != null)
2550
                    {
2551
                        soapurl = item.VALUE;
2552

    
2553
                        WebClient webClient = new WebClient();
2554
                        string data = "<soapenv:Envelope xmlns:soapenv=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:ens=\"http://EnsemblePlus.Webservice\"> <soapenv:Header/> <soapenv:Body> <ens:checkoutSignImage>"
2555
                            + "<ens:sUserNo>" + user_id + "</ens:sUserNo>"
2556
                            + "</ens:checkoutSignImage> </soapenv:Body></soapenv:Envelope>";
2557
                        webClient.Headers.Add(HttpRequestHeader.ContentType, "text/xml");
2558
                        webClient.Headers.Add("SOAPAction", "http://EnsemblePlus.Webservice");
2559
                        var _result = webClient.UploadString(new Uri(soapurl), data);
2560
                        XmlDocument xmlDoc = new XmlDocument();
2561
                        xmlDoc.LoadXml(_result);
2562
                        XmlNodeList list = xmlDoc.GetElementsByTagName("checkoutSignImageResponse");
2563

    
2564
                        foreach (XmlNode xn in list)
2565
                        {
2566
                            result = xn["checkoutSignImageReturn"].InnerText;
2567
                        }
2568

    
2569
                        if (result.Contains("No business object"))
2570
                        {
2571
                            result = null;
2572
                        }
2573
                    }
2574
                    else
2575
                    {
2576
                        result = null;
2577
                    }
2578
                }
2579
             
2580
            }
2581
            catch (Exception ex)
2582
            {   
2583
                result = null;
2584
            }
2585

    
2586
            return result;
2587
        }
2588
        #endregion
2589

    
2590
        #region Final Service
2591
        [OperationContract]
2592
        [ServiceKnownType(typeof(DOCINFO))]                
2593
        public DOCINFO FinalPDF_GetDocinfo(string project_no, string docinfo_id)
2594
        {
2595
            DOCINFO docinfo = null;
2596

    
2597
            try
2598
            {
2599
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2600
                using (CIEntities _entity = new CIEntities(sCIConnString))
2601
                {
2602
                    var doc = _entity.DOCINFO.Where(x => x.ID == docinfo_id).FirstOrDefault();
2603
                    if(doc != null)
2604
                    {
2605
                        docinfo = new DOCINFO()
2606
                        {
2607
                            ID = doc.ID,
2608
                            DOCUMENT_ID = doc.DOCUMENT_ID,
2609
                            PAGE_COUNT = doc.PAGE_COUNT,
2610
                            ORIGINAL_FILE = doc.ORIGINAL_FILE,
2611
                            PROJECT_NO = doc.PROJECT_NO
2612
                        };
2613
                    }                    
2614
                }
2615
            }
2616
            catch (Exception)
2617
            {
2618
                throw;
2619
            }
2620
            return docinfo;
2621
        }
2622
        [OperationContract]
2623
        [ServiceKnownType(typeof(DOCUMENT_ITEM))]
2624
        public DOCUMENT_ITEM FinalPDF_GetDocumentItem(string project_no, string document_id)
2625
        {
2626
            DOCUMENT_ITEM item = null;
2627

    
2628
            try
2629
            {
2630
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2631
                using (CIEntities _entity = new CIEntities(sCIConnString))
2632
                {
2633
                    var doc = _entity.DOCUMENT_ITEM.Where(x => x.DOCUMENT_ID == document_id).FirstOrDefault();
2634
                    if(doc != null)
2635
                    {
2636
                        item = new DOCUMENT_ITEM()
2637
                        {
2638
                            ID = doc.ID,
2639
                            ORIGINAL_FILE = doc.ORIGINAL_FILE,
2640
                            PROJECT_NO = doc.PROJECT_NO,
2641
                            DOCUMENT_ID = doc.DOCUMENT_ID,
2642
                            DOCUMENT_NO = doc.DOCUMENT_NO,
2643
                            DOCUMENT_NAME = doc.DOCUMENT_NAME,
2644
                            //ENSEMBLEINFO_URL = doc.ENSEMBLEINFO_URL,
2645
                            GROUP_NO = doc.GROUP_NO,
2646
                            RESULT = doc.RESULT,
2647
                            REVISION = doc.REVISION,
2648
                            RESULT_FILE = doc.RESULT_FILE
2649
                        };
2650
                    }
2651
                    
2652
                }
2653
            }
2654
            catch (Exception)
2655
            {
2656
                throw;
2657
            }
2658
            return item;
2659
        }
2660
        [OperationContract]
2661
        [ServiceKnownType(typeof(MARKUP_DATA))]
2662
        public List<MARKUP_DATA> FinalPDF_GetMarkupdata(string project_no, string docinfo_id)
2663
        {
2664
            List<MARKUP_DATA> results = new List<MARKUP_DATA>();
2665

    
2666
            try
2667
            {
2668
                //using (CIEntities _entity = new CIEntities(ConnectStringBuilder.ProjectCIConnectString(project_no).ToString()))
2669
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2670
                using (CIEntities _entity = new CIEntities(sCIConnString))
2671
                {
2672
                    var datas = _entity.MARKUP_DATA.Where(x => x.MARKUP_INFO_VERSION.MARKUP_INFO.DOCINFO_ID == docinfo_id
2673
                    && x.MARKUP_INFO_VERSION.MARKUP_INFO.CONSOLIDATE == 1
2674
                    && x.MARKUP_INFO_VERSION.MARKUP_INFO.AVOID_CONSOLIDATE == 0
2675
                    && x.MARKUP_INFO_VERSION.MARKUP_INFO.PART_CONSOLIDATE == 0).ToList();
2676
                    foreach (var data in datas)
2677
                    {
2678
                        MARKUP_DATA d = new MARKUP_DATA()
2679
                        {
2680
                            ID = data.ID,
2681
                            //GROUP_ID = data.GROUP_ID,
2682
                            SYMBOL_ID = data.SYMBOL_ID,
2683
                            DATA = data.DATA,
2684
                            DATA_TYPE = data.DATA_TYPE,
2685
                            MARKUPINFO_VERSION_ID = data.MARKUPINFO_VERSION_ID,
2686
                            PAGENUMBER = data.PAGENUMBER
2687
                        };
2688
                        results.Add(d);
2689
                    }
2690
                }
2691
            }
2692
            catch (Exception)
2693
            {
2694
                throw;
2695
            }
2696
            return results;
2697
        }
2698
        [OperationContract]
2699
        [ServiceKnownType(typeof(MARKUP_INFO))]
2700
        public MARKUP_INFO FinalPDF_GetMarkupinfo(string project_no, string docinfo_id)
2701
        {
2702
            MARKUP_INFO markupInfo = null;
2703

    
2704
            try
2705
            {
2706
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2707
                using (CIEntities _entity = new CIEntities(sCIConnString))
2708
                {
2709
                    var tmp = _entity.MARKUP_INFO.Where(x => x.DOCINFO_ID == docinfo_id && x.CONSOLIDATE == 1 && x.AVOID_CONSOLIDATE == 0 && x.PART_CONSOLIDATE == 0).FirstOrDefault();
2710
                    if (tmp != null)
2711
                    {
2712
                        markupInfo = new MARKUP_INFO()
2713
                        {
2714
                            ID = tmp.ID,
2715
                            DOCINFO_ID = tmp.DOCINFO_ID,
2716
                            USER_ID = tmp.USER_ID
2717
                        };
2718
                    }                    
2719
                }
2720
            }
2721
            catch (Exception)
2722
            {
2723
                throw;
2724
            }
2725
            return markupInfo;
2726
        }
2727
        [OperationContract]
2728
        [ServiceKnownType(typeof(FINAL_PDF))]
2729
        public List<FINAL_PDF> FinalPDF_GetFinalPDFs(string final_id)
2730
        {
2731
            List<FINAL_PDF> results = new List<FINAL_PDF>();
2732

    
2733
            try
2734
            {
2735
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2736
                using (KCOMEntities _entity = new KCOMEntities(sConnString))
2737
                {
2738
                    var finalList = _entity.FINAL_PDF.Where(final => final.ID == final_id).ToList();
2739
                    foreach(var final in finalList)
2740
                    {
2741
                        FINAL_PDF pdf = new FINAL_PDF()
2742
                        {
2743
                            ID = final.ID,
2744
                            DOCINFO_ID = final.DOCINFO_ID,
2745
                            DOCUMENT_ID = final.DOCUMENT_ID,
2746
                            STATUS = final.STATUS,
2747
                            CURRENT_PAGE = final.CURRENT_PAGE,
2748
                            CREATE_DATETIME = final.CREATE_DATETIME,
2749
                            START_DATETIME = final.START_DATETIME,
2750
                            END_DATETIME = final.END_DATETIME,
2751
                            EXCEPTION = final.EXCEPTION,
2752
                            PROJECT_NO = final.PROJECT_NO,
2753
                            TOTAL_PAGE = final.TOTAL_PAGE,
2754
                            MARKUPINFO_ID = final.MARKUPINFO_ID,
2755
                            CREATE_USER_ID = final.CREATE_USER_ID
2756
                        };
2757
                        results.Add(pdf);
2758
                    }
2759
                }
2760
            }
2761
            catch (Exception)
2762
            {
2763
                throw;
2764
            }
2765
            return results;
2766
        }
2767
        [OperationContract]
2768
        [ServiceKnownType(typeof(DOCPAGE))]
2769
        public List<DOCPAGE> FinalPDF_GetDocpage(string project_no, string docinfo_id)
2770
        {
2771
            List<DOCPAGE> results = new List<DOCPAGE>();
2772

    
2773
            try
2774
            {
2775
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2776
                using (CIEntities _entity = new CIEntities(sCIConnString))
2777
                {
2778
                    var pages = _entity.DOCPAGE.Where(x => x.DOCINFO_ID == docinfo_id).OrderBy(x => x.PAGE_NUMBER).ToList();
2779
                    foreach(var page in pages)
2780
                    {
2781
                        DOCPAGE p = new DOCPAGE()
2782
                        {
2783
                            PAGE_ANGLE = page.PAGE_ANGLE,
2784
                            PAGE_NUMBER = page.PAGE_NUMBER,
2785
                            PAGE_HEIGHT = page.PAGE_HEIGHT,
2786
                            PAGE_WIDTH = page.PAGE_WIDTH,
2787
                            DOCINFO_ID = page.DOCINFO_ID                            
2788
                        };
2789
                        results.Add(p);
2790
                    }                    
2791
                }
2792
            }
2793
            catch (Exception)
2794
            {
2795
                throw;
2796
            }
2797
            return results;
2798
        }
2799
        [OperationContract]        
2800
        public bool FinalPDF_SetFinalPDFStatus(string final_id, FinalStatus status)
2801
        {
2802
            bool result = false;
2803

    
2804
            try
2805
            {
2806
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2807
                using (KCOMEntities _entity = new KCOMEntities(sConnString))
2808
                {
2809
                    var tmp = _entity.FINAL_PDF.Where(x => x.ID == final_id).FirstOrDefault();
2810
                    if(tmp != null)
2811
                    {
2812
                        switch(status)
2813
                        {
2814
                            case FinalStatus.Create:
2815
                                tmp.START_DATETIME = DateTime.Now;
2816
                                break;
2817
                            case FinalStatus.Success:
2818
                                tmp.END_DATETIME = DateTime.Now;
2819
                                tmp.EXCEPTION = string.Empty;
2820
                                break;                                
2821
                        }
2822
                        tmp.STATUS = (int)status;
2823
                        _entity.SaveChanges();
2824
                        result = true;                        
2825
                    }
2826
                }                    
2827
            }
2828
            catch (Exception)
2829
            {
2830
                throw;
2831
            }
2832
            return result;
2833
        }
2834

    
2835
        /// <summary>
2836
        /// 현재 진행중인 Final PDF 가 없거나 Success 일 경우에만 true return
2837
        /// </summary>
2838
        /// <param name="DocInfoID"></param>
2839
        /// <param name="MarkupInfoID"></param>
2840
        /// <param name="CreateUserID"></param>
2841
        /// <returns></returns>
2842
        [OperationContract]
2843
        public bool FinalPDF_GetFinalPDFStatus(string DocInfoID, string MarkupInfoID, string CreateUserID)
2844
        {
2845
            bool result = false;
2846

    
2847
            try
2848
            {
2849
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2850
                using (KCOMEntities _entity = new KCOMEntities(sConnString))
2851
                {
2852
                    var finalpdf = _entity.FINAL_PDF.Where(x => x.DOCINFO_ID == DocInfoID && x.MARKUPINFO_ID == MarkupInfoID && x.CREATE_USER_ID == CreateUserID && x.STATUS != (int)FinalStatus.Error).FirstOrDefault();
2853
                    if (finalpdf != null)
2854
                    {
2855
                        if (finalpdf.STATUS == (int)FinalStatus.Success)
2856
                        {
2857
                            result = true;
2858
                        }
2859
                    }
2860
                    else
2861
                        result = true;
2862
                }
2863
            }
2864
            catch (Exception)
2865
            {
2866
                throw;
2867
            }
2868
            return result;
2869
        }
2870

    
2871
        [OperationContract]
2872
        public bool FinalPDF_SetCurrentPage(string final_id, int currentpage)
2873
        {
2874
            bool result = false;
2875

    
2876
            try
2877
            {
2878
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2879
                using (KCOMEntities _entity = new KCOMEntities(sConnString))
2880
                {
2881
                    var tmp = _entity.FINAL_PDF.Where(x => x.ID == final_id).FirstOrDefault();
2882
                    if (tmp != null)
2883
                    {
2884
                        tmp.CURRENT_PAGE = currentpage;
2885
                        _entity.SaveChanges();
2886
                        result = true;
2887
                    }
2888
                }
2889
            }
2890
            catch (Exception)
2891
            {
2892
                throw;
2893
            }
2894
            return result;
2895
        }
2896
        [OperationContract]
2897
        public bool FinalPDF_SetError(string final_id, string msg)
2898
        {
2899
            bool result = false;
2900

    
2901
            try
2902
            {
2903
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2904
                using (KCOMEntities _entity = new KCOMEntities(sConnString))
2905
                {
2906
                    var tmp = _entity.FINAL_PDF.Where(x => x.ID == final_id).FirstOrDefault();
2907
                    if (tmp != null)
2908
                    {                        
2909
                        tmp.STATUS = (int)FinalStatus.Error;
2910
                        tmp.EXCEPTION = DateTime.Now.ToShortDateString() + " " + msg;                        
2911
                        _entity.SaveChanges();
2912
                        result = true;
2913
                    }
2914
                }
2915
            }
2916
            catch (Exception)
2917
            {
2918
                throw;
2919
            }
2920
            return result;
2921
        }
2922

    
2923
        [OperationContract]
2924
        public bool FinalPDF_SetFinalResultPath(string project_no, string document_id, string url)
2925
        {
2926
            bool result = false;
2927

    
2928
            try
2929
            {
2930
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2931
                using (CIEntities _entity = new CIEntities(sCIConnString))
2932
                {
2933
                    var item = _entity.DOCUMENT_ITEM.Where(d => d.DOCUMENT_ID == document_id).FirstOrDefault();
2934
                    if (item != null)
2935
                    {
2936
                        item.RESULT_FILE = url;
2937
                        _entity.SaveChanges();
2938
                        result = true;
2939
                    }
2940
                }
2941
            }
2942
            catch (Exception)
2943
            {
2944
                throw;
2945
            }
2946
            return result;
2947
        }
2948
        [OperationContract]
2949
        [ServiceKnownType(typeof(MEMBER))]
2950
        public MEMBER FinalPDF_GetCommentMember(string project_no, string markupdata_id)
2951
        {
2952
            MEMBER member = null;
2953
            try
2954
            {
2955
                string sCIConnString = ConfigurationManager.ConnectionStrings["CIConnectionString"].ConnectionString;
2956
                using (CIEntities _entity = new CIEntities(sCIConnString))
2957
                {
2958
                    var data = _entity.MARKUP_DATA.Where(x => x.ID == markupdata_id).FirstOrDefault();
2959
                    string user_id = data.MARKUP_INFO_VERSION.MARKUP_INFO.USER_ID;
2960
                    var person = _entity.MEMBER.Where(p => p.ID == user_id).FirstOrDefault();
2961
                    if(person != null)
2962
                    {
2963
                        member = new MEMBER()
2964
                        {
2965
                            ID = user_id,
2966
                            NAME = person.NAME,
2967
                            DEPARTMENT = person.DEPARTMENT
2968
                        };
2969
                    }
2970
                }
2971
            }
2972
            catch (Exception)
2973
            {
2974
                throw;
2975
            }
2976
            return member;
2977
        }
2978

    
2979
        [OperationContract]
2980
        [ServiceKnownType(typeof(PROPERTIES))]
2981
        public List<PROPERTIES> FinalPDF_GetProperties(string project_no)
2982
        {
2983
            List<PROPERTIES> results = new List<PROPERTIES>();
2984
            try
2985
            {
2986
                string sConnString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
2987
                using (KCOMEntities _entity = new KCOMEntities(sConnString))
2988
                {
2989
                    var _items = _entity.PROPERTIES.Where(x => x.PROPERTY == project_no).ToList();
2990
                    foreach(var item in _items)
2991
                    {
2992
                        PROPERTIES pROPERTIES = new PROPERTIES()
2993
                        {
2994
                            ID = item.ID,
2995
                            PROPERTY = item.PROPERTY,
2996
                            TYPE = item.TYPE,
2997
                            VALUE = item.VALUE
2998
                        };
2999
                        results.Add(pROPERTIES);
3000
                    }
3001
                }
3002

    
3003
            }
3004
            catch (Exception)
3005
            {
3006
                throw;
3007
            }
3008
            return results;
3009
        }
3010
        #endregion
3011
    }    
3012
}
클립보드 이미지 추가 (최대 크기: 500 MB)