annotate src/mngdb.cpp @ 13:f5ffc34f045a

manage DB.
author pyon@macmini
date Wed, 14 Nov 2018 19:43:40 +0900
parents 799b6008db8e
children c1dc1fcee7fe
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
1 // Filename : mngdeb.cpp
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
2 // Last Change: 2018-11-14 水 13:48:58.
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
3 //
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
4
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
5 #include <wx/datetime.h>
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
6 #include <wx/textfile.h>
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
7 #include "id.h"
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
8 #include "mngdb.h"
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
9
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
10 ManageDBFrame::ManageDBFrame( wxWindow* parent, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, long style )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
11 : wxFrame( parent, id, title, pos, size, style )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
12 {
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
13 this->SetBackgroundColour( wxColour( 140, 240, 140 ) );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
14 this->SetSizeHints( wxDefaultSize, wxDefaultSize );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
15
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
16 wxBoxSizer* bSizerTop = new wxBoxSizer( wxVERTICAL );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
17
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
18 wxFlexGridSizer* fgSizer = new wxFlexGridSizer( 0, 2, 0, 0 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
19 fgSizer->SetFlexibleDirection( wxBOTH );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
20 fgSizer->SetNonFlexibleGrowMode( wxFLEX_GROWMODE_SPECIFIED );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
21
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
22 m_staticTextDate = new wxStaticText( this, wxID_ANY, wxT( "Date" ), wxDefaultPosition, wxDefaultSize, 0 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
23 fgSizer->Add( m_staticTextDate, 0, wxALL|wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
24
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
25 m_datePicker = new wxDatePickerCtrl( this, wxID_ANY, wxDefaultDateTime, wxDefaultPosition, wxSize( 180, -1 ), wxDP_DROPDOWN|wxDP_SHOWCENTURY );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
26 fgSizer->Add( m_datePicker, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
27
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
28 m_staticTextHhs = new wxStaticText( this, wxID_ANY, wxT( "HHS" ), wxDefaultPosition, wxDefaultSize, 0 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
29 fgSizer->Add( m_staticTextHhs, 0, wxALL|wxALIGN_CENTER_VERTICAL|wxALIGN_RIGHT, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
30
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
31 m_filePickerHhs = new wxFilePickerCtrl( this, wxID_ANY, wxEmptyString, wxT( "Select a file" ), wxT( "*.db" ), wxDefaultPosition, wxSize( 180, -1 ), wxFLP_FILE_MUST_EXIST|wxFLP_OPEN|wxFLP_SMALL|wxFLP_USE_TEXTCTRL );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
32 fgSizer->Add( m_filePickerHhs, 0, wxALL|wxALIGN_CENTER_VERTICAL|wxEXPAND, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
33
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
34 m_staticTextCcn = new wxStaticText( this, wxID_ANY, wxT( "CCN" ), wxDefaultPosition, wxDefaultSize, 0 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
35 fgSizer->Add( m_staticTextCcn, 0, wxALL|wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
36
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
37 m_filePickerCcn = new wxFilePickerCtrl( this, wxID_ANY, wxEmptyString, wxT( "Select a file" ), wxT( "*.db" ), wxDefaultPosition, wxSize( 180, -1 ), wxFLP_FILE_MUST_EXIST|wxFLP_OPEN|wxFLP_SMALL|wxFLP_USE_TEXTCTRL );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
38 fgSizer->Add( m_filePickerCcn, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
39
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
40 bSizerTop->Add( fgSizer, 0, wxALIGN_CENTER_HORIZONTAL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
41
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
42 //---
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
43 m_staticline = new wxStaticLine( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLI_HORIZONTAL );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
44 bSizerTop->Add( m_staticline, 0, wxEXPAND|wxALL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
45
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
46 wxBoxSizer* bSizerBtn = new wxBoxSizer( wxHORIZONTAL );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
47
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
48 m_buttonBuild = new wxButton( this, ID_MNGBLD, wxT( "Build" ), wxDefaultPosition, wxDefaultSize, 0 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
49 bSizerBtn->Add( m_buttonBuild, 0, wxALL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
50
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
51 m_buttonUpld = new wxButton( this, ID_MNGUPLD, wxT( "Upload" ), wxDefaultPosition, wxDefaultSize, 0 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
52 bSizerBtn->Add( m_buttonUpld, 0, wxALL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
53
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
54 m_buttonExit = new wxButton( this, ID_MNGEXIT, wxT( "Exit" ), wxDefaultPosition, wxDefaultSize, 0 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
55 bSizerBtn->Add( m_buttonExit, 0, wxALL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
56
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
57 bSizerTop->Add( bSizerBtn, 0, wxALIGN_CENTER_HORIZONTAL, 5 );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
58
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
59 this->SetSizer( bSizerTop );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
60 this->Layout();
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
61
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
62 this->Centre( wxBOTH );
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
63 m_buttonUpld->Enable( false );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
64 }
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
65
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
66 ManageDBFrame::~ManageDBFrame()
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
67 {
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
68 }
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
69
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
70 // Event Table
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
71 BEGIN_EVENT_TABLE( ManageDBFrame, wxFrame )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
72 EVT_BUTTON( ID_MNGBLD, ManageDBFrame::OnBuild )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
73 EVT_BUTTON( ID_MNGUPLD, ManageDBFrame::OnUpload )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
74 EVT_BUTTON( ID_MNGEXIT, ManageDBFrame::OnExit )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
75 END_EVENT_TABLE()
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
76
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
77 // Event Handler
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
78 void ManageDBFrame::OnBuild( wxCommandEvent& WXUNUSED(event) )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
79 {
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
80 wxString hhs = m_filePickerHhs->GetPath();
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
81 wxString ccn = m_filePickerCcn->GetPath();
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
82 wxDateTime dt = m_datePicker->GetValue();
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
83 wxString ymd = dt.Format( wxT( "%Y%m%d" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
84
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
85 // index.db.tmp, hhs.csv.tmp(utf-8)
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
86 wxArrayString args;
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
87 args.Add( wxT( "extsql.exe" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
88 args.Add( hhs );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
89 args.Add( ccn );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
90 args.Add( ymd );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
91 wxExecute( wxJoin( args, ' ', '\\' ), wxEXEC_SYNC|wxEXEC_HIDE_CONSOLE );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
92
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
93 // hhs.csv(cp932)
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
94 wxCSConv cust( wxT( "cp932" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
95 wxTextFile input( wxT( "hhs.csv.tmp" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
96 wxTextFile output( wxT( "hhs.csv" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
97 input.Open();
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
98 output.Create();
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
99 for ( wxString buf = input.GetFirstLine(); !input.Eof(); buf = input.GetNextLine() )
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
100 output.AddLine( buf );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
101 input.Close();
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
102 output.Write( wxTextFileType_Dos, cust );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
103 output.Close();
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
104
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
105 // hhs.db(encryptoed)
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
106 wxString key = wxT( "12345678900123456789abcdefabcdef" );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
107 args.Clear();
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
108 args.Add( wxT( "crypto.exe" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
109 args.Add( wxT( "-e" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
110 args.Add( wxT( "hhs.csv" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
111 args.Add( wxT( "-k" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
112 args.Add( key );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
113 args.Add( wxT( "-o" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
114 args.Add( wxT( "hhs.db" ) );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
115 wxExecute( wxJoin( args, ' ', '\\' ), wxEXEC_SYNC|wxEXEC_HIDE_CONSOLE );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
116
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
117 wxMessageBox( wxT( "build done." ) );
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
118 m_buttonUpld->Enable( true );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
119 }
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
120
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
121 void ManageDBFrame::OnUpload( wxCommandEvent& WXUNUSED(event) )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
122 {
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
123 Upload( wxT( "index.db" ) );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
124 Upload( wxT( "hhs.db" ) );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
125 wxMessageBox( wxT( "upload done." ) );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
126 }
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
127
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
128 void ManageDBFrame::OnExit( wxCommandEvent& WXUNUSED(event) )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
129 {
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
130 Close();
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
131 }
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
132
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
133
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
134 // Functions
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
135 void ManageDBFrame::Upload( wxString file )
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
136 {
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
137 wxArrayString args;
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
138 args.Add( wxT( "client.exe" ) );
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
139 args.Add( wxT( "-m" ) );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
140 args.Add( m_server );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
141 args.Add( file );
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
142
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
143 wxExecute( wxJoin( args, ' ', '\\' ), wxEXEC_SYNC|wxEXEC_HIDE_CONSOLE );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
144 }
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
145
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
146 void ManageDBFrame::SetDBdir( wxString dir )
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
147 {
13
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
148 wxDateTime dt;
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
149 dt.ParseFormat( wxT( "20160401" ), wxT( "%Y%m%d") );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
150 m_datePicker->SetValue( dt );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
151 m_filePickerHhs->SetPath( dir + wxFILE_SEP_PATH + wxT( "hhs.db") );
f5ffc34f045a manage DB.
pyon@macmini
parents: 11
diff changeset
152 m_filePickerCcn->SetPath( dir + wxFILE_SEP_PATH + wxT( "ccn.db") );
11
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
153 }
799b6008db8e auto-upgrade.
pyon@macmini
parents:
diff changeset
154