프로젝트

일반

사용자정보

통계
| 개정판:

hytos / DTI_PID / ID2PSN / Program.cs @ 23a96301

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

1
using Newtonsoft.Json;
2
using System;
3
using System.Collections.Generic;
4
using System.Data;
5
using System.IO;
6
using System.Linq;
7
using System.Net.Sockets;
8
using System.Text;
9
using System.Threading.Tasks;
10
using System.Windows.Forms;
11

    
12
namespace ID2PSN
13
{
14
    static class Program
15
    {
16
        /// <summary>
17
        /// 해당 애플리케이션의 주 진입점입니다.
18
        /// </summary>
19
        [STAThread]
20
        static void Main(string[] args)
21
        {
22
            if (!SingleInstance.Start("ecf2ed2e-1a3f-4926-a561-512857785805"))
23
            {
24
                return;
25
            }
26

    
27
            ID2Info info = ID2Info.GetInstance();
28
            DataTable projectTable = null;
29
            try
30
            {
31
                //DB Type 확인
32
                projectTable = DB.GetProject();
33
                
34

    
35
                using (TcpClient tcpClient = new TcpClient())
36
                {
37
                    tcpClient.SendTimeout = 500;
38
                    tcpClient.Connect("localhost", 2549);
39

    
40
                    var _params = new Dictionary<string, string>()
41
                    {
42
                        {"request", "database" },
43
                    };
44
                    var json = JsonConvert.SerializeObject(_params, Formatting.Indented);
45
                    byte[] message = Encoding.UTF8.GetBytes(json);
46

    
47
                    using (NetworkStream networkStream = tcpClient.GetStream())
48
                    {
49
                        networkStream.Write(message, 0, message.Length);
50

    
51
                        byte[] outbuf = new byte[1024];
52
                        int nbytes = networkStream.Read(outbuf, 0, outbuf.Length);
53
                        string output = Encoding.UTF8.GetString(outbuf, 4, nbytes - 5);
54
                        var result = JsonConvert.DeserializeObject<Dictionary<string, string>>(output);
55

    
56

    
57
                        if (result["db_type"] == "SQLite")
58
                        {
59
                            info.ID2DBType = ID2DB_Type.SQLite;
60
                            var parent = Directory.GetParent(Path.GetDirectoryName(result["db_name"]));
61
                            info.DefaultPath = parent.ToString();
62
                            ///DataRow dr = projectTable.Select(string.Format("DBTypes_UID = 2 AND Name = '{0}'", result["db_name"])).FirstOrDefault();
63
                            ///info.DefaultPath = dr.Field<string>("Path");
64
                        }
65
                        else if (result["db_type"] == "MSSQL")
66
                        {
67
                            info.ID2DBType = ID2DB_Type.MSSQL;
68
                            info.ServerIP = result["host"];
69
                            //info.Port = "3389"; 
70
                            info.DBUser = result["user"];
71
                            info.DBPassword = result["password"];
72
                            info.Database = result["db_name"];
73
                            DataRow dr = projectTable.Select(string.Format("DBTypes_UID = 2 AND Name = '{0}'", result["db_name"])).FirstOrDefault();
74
                            info.DefaultPath = dr.Field<string>("Path");
75
                        }
76
                    }
77
                    tcpClient.Close();
78
                }
79

    
80
                if (DB.ConnTestAndCreateTable())
81
                {
82
                    Application.EnableVisualStyles();
83
                    Application.SetCompatibleTextRenderingDefault(false);
84
                    Application.Run(new MainForm());
85
                }
86
                else
87
                    MessageBox.Show("fail");
88
            }
89
            catch (Exception ex)
90
            {
91
                MessageBox.Show("Failed to open ID2 drawing.", "ID2PSN", MessageBoxButtons.OK, MessageBoxIcon.Error);
92
            }
93
        }
94
    }
95
}