프로젝트

일반

사용자정보

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

hytos / ID2.Manager / ID2.Manager.Controller / Controllers / ProjectController.cs @ 378846cd

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

1
using System;
2
using System.Collections.Generic;
3
using System.Linq;
4
using System.Text;
5
using System.Threading.Tasks;
6

    
7
using ID2.Manager.Data.Models;
8
using ID2.Manager.Dapper.Repository;
9

    
10
namespace ID2.Manager.Controller.Controllers
11
{
12
    public class ProjectController : BaseController
13
    {
14
        public ProjectController() : base() { }
15

    
16
        public ProjectController(ID2ProjectInfo id2Info) : base(id2Info) { }
17

    
18
        public IEnumerable<ProjectInfo> GetAllProjectList()
19
        {
20
            try
21
            {
22
                using (ProjectRepository rep = new ProjectRepository(this._MSSQLCONNSTR))
23
                {
24
                    var id2Project = new ID2Controller().GetID2ProjectList();
25
                    var allProject = rep.GetAllProjectList();
26

    
27
                    foreach (var id2Prj in id2Project)
28
                    {
29
                        string ID2Port = string.Empty;
30
                        try
31
                        {
32
                            ID2Port = new ProjectController(id2Prj).GetID2PortByProject();
33
                        }
34
                        catch { }
35
                        if (!int.TryParse(ID2Port, out int id2Port))
36
                            id2Port = 2549;
37
                        id2Prj.Port = id2Port;
38
                    }
39

    
40
                    return from mg in allProject
41
                           join id2 in id2Project on mg.Code equals id2.Name into gj
42
                           from prjs in gj.DefaultIfEmpty()
43
                           select new ProjectInfo()
44
                           {
45
                               ProjectID = mg.ProjectID,
46
                               Code = mg.Code,
47
                               Name = mg.Name,
48
                               Description = mg.Description,
49
                               ID2Path = prjs?.Path ?? null,
50
                               GroupID = mg.GroupID,
51
                               GroupName = mg.GroupName,
52
                               Team = mg.Team,
53
                               Port = prjs?.Port,
54
                               Level = mg.Level,
55
                               ID2Info = prjs ?? new ID2ProjectInfo(),
56
                           };
57
                }
58
            }
59
            catch (Exception ex)
60
            {
61
                throw ex;
62
            }
63
        }
64

    
65
        public ProjectInfo GetProjectInfo(string ProjectID)
66
        {
67
            try
68
            {
69
                using (ProjectRepository rep = new ProjectRepository(this._MSSQLCONNSTR))
70
                {
71
                    var id2Project = new ID2Controller().GetID2ProjectList();
72
                    var project = rep.GetProjectInfo(ProjectID);
73

    
74
                    var id2 = id2Project.Where(x => x.Name.Equals(project.Code)).FirstOrDefault();
75
                    project.ID2Path = id2?.Path ?? null;
76
                    project.ID2Info = id2 ?? new ID2ProjectInfo();
77

    
78
                    return rep.GetProjectInfo(ProjectID);
79
                }
80
            }
81
            catch (Exception ex)
82
            {
83
                throw ex;
84
            }
85
        }
86

    
87
        public bool SetProjectData(ProjectInfo projectInfo, List<ID2ProjectInfo> id2ProjectList)
88
        {
89
            try
90
            {
91
                using (ProjectRepository rep = new ProjectRepository(this._MSSQLCONNSTR))
92
                {
93
                    return rep.SetProjectData(projectInfo, id2ProjectList);
94
                }
95
            }
96
            catch (Exception ex)
97
            {
98
                throw ex;
99
            }
100
        }
101

    
102
        public bool SetProjectGroupData(ProjectInfo projectInfo)
103
        {
104
            try
105
            {
106
                using (ProjectRepository rep = new ProjectRepository(this._MSSQLCONNSTR))
107
                {
108
                    return rep.SetProjectGroupData(projectInfo);
109
                }
110
            }
111
            catch (Exception ex)
112
            {
113
                throw ex;
114
            }
115
        }
116

    
117
        //ID2
118
        public string GetID2PortByProject()
119
        {
120
            try
121
            {
122
                using (ProjectRepository rep = new ProjectRepository(this._ID2CONNSTR))
123
                {
124
                    return rep.GetID2PortByProject();
125
                }
126
            }
127
            catch (Exception ex)
128
            {
129
                throw ex;
130
            }
131
        }
132
    }
133
}
클립보드 이미지 추가 (최대 크기: 500 MB)