mirror of
https://github.com/MariaDB/server.git
synced 2025-01-25 00:04:33 +01:00
19dbf58eec
mysqld >=4.1.3 will however understand shutdown requests sent by clients <4.1.3. And mysqld <4.1.3 will understand shutdown requests sent by clients >=4.1.3 (it will ignore the level). Those shutdown level are just PLACEHOLDERS now. So this change is just to make the 4.1 API suitable before it is frozen. Later we will actually implement the shutdown levels.
2529 lines
68 KiB
C++
2529 lines
68 KiB
C++
//---------------------------------------------------------------------------
|
|
#include <vcl.h>
|
|
#pragma hdrstop
|
|
|
|
#include "main.h"
|
|
#include "initsetup.h"
|
|
#include "db.h"
|
|
|
|
//---------------------------------------------------------------------------
|
|
#pragma package(smart_init)
|
|
#pragma resource "*.dfm"
|
|
#include <shellapi.h>
|
|
#include <registry.hpp>
|
|
#include <winsvc.h>
|
|
#include <winsock.h>
|
|
#include <shlobj.h>
|
|
#include <IniFiles.hpp>
|
|
#include <dir.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <deque.h>
|
|
#include <vector.h>
|
|
#include <fstream.h>
|
|
#include <iostream.h>
|
|
#include <iterator.h>
|
|
#include <sstream.h>
|
|
#include "mysql.h"
|
|
#include <Printers.hpp>
|
|
|
|
TForm1 *Form1;
|
|
bool i_start, NT;
|
|
bool IsForce = false;
|
|
bool IsVariables = false;
|
|
bool IsProcess = false ;
|
|
bool IsDatabases = false;
|
|
bool new_line = 0;
|
|
bool ya = true;
|
|
bool yy = true;
|
|
bool rinit = false;
|
|
AnsiString vpath;
|
|
AnsiString vip;
|
|
MYSQL_RES *res_1;
|
|
static unsigned long q = 0;
|
|
bool preport = false;
|
|
bool treport = false;
|
|
bool ereport = false;
|
|
AnsiString mainroot;
|
|
bool IsMySQLNode = false;
|
|
MYSQL *MySQL;
|
|
//---------------------------------------------------------------------------
|
|
__fastcall TForm1::TForm1(TComponent* Owner)
|
|
: TForm(Owner)
|
|
{
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::FormCreate(TObject *Sender)
|
|
{
|
|
i_start = true;
|
|
IsConnect = false;
|
|
if (ParamCount() > 0){
|
|
if (ParamStr(1) == "-h" || ParamStr(1) == "h" ) {
|
|
ShowHelp(); Application->Terminate(); }
|
|
else if (ParamStr(1) == "-w" || ParamStr(1) == "w") {
|
|
i_start = false; ContinueLoad(); }
|
|
}
|
|
else {
|
|
ContinueLoad(); Hide(); GetServerOptions(); }
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::DrawItem(TMessage& Msg)
|
|
{
|
|
IconDrawItem((LPDRAWITEMSTRUCT)Msg.LParam);
|
|
TForm::Dispatch(&Msg);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::MyNotify(TMessage& Msg)
|
|
{
|
|
POINT MousePos;
|
|
|
|
switch(Msg.LParam) {
|
|
case WM_RBUTTONUP:
|
|
if (GetCursorPos(&MousePos)){
|
|
PopupMenu1->PopupComponent = Form1; SetForegroundWindow(Handle);
|
|
PopupMenu1->Popup(MousePos.x, MousePos.y);}
|
|
else Show();
|
|
break;
|
|
case WM_LBUTTONUP:
|
|
if (GetCursorPos(&MousePos)){
|
|
PopupMenu1->PopupComponent = Form1; SetForegroundWindow(Handle);
|
|
PopupMenu1->Popup(MousePos.x, MousePos.y); }
|
|
|
|
ToggleState();
|
|
break;
|
|
default:
|
|
break; }
|
|
|
|
TForm::Dispatch(&Msg);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::TrayMessage(DWORD dwMessage)
|
|
{
|
|
NOTIFYICONDATA tnd;
|
|
PSTR pszTip;
|
|
|
|
pszTip = TipText();
|
|
|
|
tnd.cbSize = sizeof(NOTIFYICONDATA);
|
|
tnd.hWnd = Handle;
|
|
tnd.uID = IDC_MYICON;
|
|
tnd.uFlags = NIF_MESSAGE | NIF_ICON | NIF_TIP;
|
|
tnd.uCallbackMessage = MYWM_NOTIFY;
|
|
|
|
if (dwMessage == NIM_MODIFY){
|
|
tnd.hIcon = IconHandle();
|
|
if (pszTip)lstrcpyn(tnd.szTip, pszTip, sizeof(tnd.szTip));
|
|
else tnd.szTip[0] = '\0'; }
|
|
else { tnd.hIcon = NULL; tnd.szTip[0] = '\0'; }
|
|
|
|
return (Shell_NotifyIcon(dwMessage, &tnd));
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
HANDLE __fastcall TForm1::IconHandle(void)
|
|
{
|
|
|
|
if (!NT){
|
|
if (MySQLSignal()){Image3->Visible = false; Image2->Visible = true;
|
|
return (Image2->Picture->Icon->Handle); }
|
|
else {Image2->Visible = false; Image3->Visible = true;
|
|
return (Image3->Picture->Icon->Handle); }
|
|
}
|
|
else {
|
|
if (TheServiceStatus()){Image3->Visible = false; Image2->Visible = true;
|
|
return (Image2->Picture->Icon->Handle); }
|
|
|
|
else if (MySQLSignal()){Image3->Visible = false; Image2->Visible = true;
|
|
return (Image2->Picture->Icon->Handle); }
|
|
else {Image2->Visible = false; Image3->Visible = true;
|
|
return (Image3->Picture->Icon->Handle); }
|
|
}
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::ToggleState(void)
|
|
{
|
|
|
|
TrayMessage(NIM_MODIFY);
|
|
if (!NT){
|
|
if (MySQLSignal()){SSW9->Caption = "ShutDown the Server";
|
|
Image3->Visible = false; Image2->Visible = true; }
|
|
else {SSW9->Caption = "Start the Server";
|
|
Image2->Visible = false; Image3->Visible = true; }
|
|
}
|
|
else {
|
|
if (TheServiceStart()) {
|
|
Standa->Enabled = false;
|
|
if (TheServiceStatus()) {RService->Enabled = false;
|
|
StopS->Enabled = true;
|
|
StopS->Caption = "Stop the Service";
|
|
Image3->Visible = false;
|
|
Image2->Visible = true; }
|
|
else {RService->Enabled = true;
|
|
StopS->Enabled = true;
|
|
RService->Caption = "Remove the Service";
|
|
StopS->Caption = "Start the Service";
|
|
Image2->Visible = false;
|
|
Image3->Visible = true; }
|
|
}
|
|
else {
|
|
Standa->Enabled = true;
|
|
StopS->Enabled = false;
|
|
if (MySQLSignal()) {
|
|
RService->Enabled = false;
|
|
Standa->Caption = "ShutDown the Server Standalone";
|
|
Image3->Visible = false;
|
|
Image2->Visible = true; }
|
|
|
|
else {
|
|
RService->Enabled = true;
|
|
RService->Caption = "Install the Service";
|
|
Standa->Caption = "Start the Server Standalone";
|
|
Image2->Visible = false;
|
|
Image3->Visible = true; }
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
PSTR __fastcall TForm1::TipText(void)
|
|
{
|
|
char* status = StatusLine->SimpleText.c_str();
|
|
return status;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::WMQueryEndSession(TWMQueryEndSession &msg)
|
|
{
|
|
|
|
|
|
if (!NT) {
|
|
|
|
if (MySQLSignal()){
|
|
StatusLine->SimpleText = "Shutdown in progress.....";
|
|
Show(); Shutd(); msg.Result = 1; }
|
|
else {
|
|
StatusLine->SimpleText = "The Server already is down......";
|
|
Show(); msg.Result = 1; Close(); }
|
|
}
|
|
else {
|
|
|
|
Show();
|
|
if (!TheServiceStart()) { if (MySQLSignal()) Shutd(); }
|
|
msg.Result = 1;
|
|
}
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
LRESULT IconDrawItem(LPDRAWITEMSTRUCT lpdi)
|
|
{
|
|
HICON hIcon;
|
|
|
|
hIcon = (HICON)LoadImage(g_hinst, MAKEINTRESOURCE(lpdi->CtlID), IMAGE_ICON,
|
|
16, 16, 0);
|
|
if (!hIcon)
|
|
return(false);
|
|
|
|
DrawIconEx(lpdi->hDC, lpdi->rcItem.left, lpdi->rcItem.top, hIcon,
|
|
16, 16, 0, NULL, DI_NORMAL);
|
|
|
|
return(true);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
AnsiString __fastcall TForm1::TheComputer()
|
|
{
|
|
AnsiString theword;
|
|
DWORD dwSize = MAX_COMPUTERNAME_LENGTH + 1;
|
|
char szBuf[MAX_COMPUTERNAME_LENGTH + 1];
|
|
szBuf[0] = '\0';
|
|
|
|
GetComputerName(szBuf, &dwSize);
|
|
theword = (AnsiString) szBuf;
|
|
delete [] szBuf;
|
|
return theword;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
AnsiString __fastcall TForm1::TheOS()
|
|
{
|
|
AnsiString theword;
|
|
OSVERSIONINFO info;
|
|
info.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
|
|
GetVersionEx(&info);
|
|
|
|
switch (info.dwPlatformId)
|
|
{
|
|
case VER_PLATFORM_WIN32s:
|
|
NT = false;
|
|
theword = "Win32s detected";
|
|
break;
|
|
case VER_PLATFORM_WIN32_WINDOWS:
|
|
NT = false;
|
|
theword = "Win 95 or Win 98 detected";
|
|
break;
|
|
case VER_PLATFORM_WIN32_NT:
|
|
NT = true;
|
|
theword = "Windows NT detected";
|
|
break;
|
|
}
|
|
return theword;
|
|
}
|
|
///---------------------------------------------------------------------------
|
|
AnsiString __fastcall TForm1::TheUser()
|
|
{
|
|
AnsiString theword;
|
|
DWORD dwSize = 0;
|
|
|
|
GetUserName(NULL, &dwSize);
|
|
|
|
char *szBuf = new char[dwSize];
|
|
szBuf[0] = '\0';
|
|
|
|
GetUserName(szBuf, &dwSize);
|
|
theword = (AnsiString) szBuf;
|
|
delete [] szBuf;
|
|
return theword;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::TakeIP(void)
|
|
{
|
|
WORD wVersionRequested;
|
|
WSADATA WSAData;
|
|
wVersionRequested = MAKEWORD(1,1);
|
|
WSAStartup(wVersionRequested,&WSAData);
|
|
|
|
hostent *P;
|
|
char s[128];
|
|
in_addr in;
|
|
char *P2;
|
|
gethostname(s, 128);
|
|
P = gethostbyname(s);
|
|
|
|
Memo2->Lines->Clear();
|
|
Memo2->Lines->Add((AnsiString)P->h_name);
|
|
mainroot = P->h_name;
|
|
in.S_un.S_un_b.s_b1 = P->h_addr_list[0][0];
|
|
in.S_un.S_un_b.s_b2 = P->h_addr_list[0][1];
|
|
in.S_un.S_un_b.s_b3 = P->h_addr_list[0][2];
|
|
in.S_un.S_un_b.s_b4 = P->h_addr_list[0][3];
|
|
P2 = inet_ntoa(in);
|
|
vip = P2;
|
|
mainroot += " ( " + (AnsiString)P2 + " )";
|
|
Memo2->Lines->Add(P2);
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::GetmemStatus(void)
|
|
{
|
|
MEMORYSTATUS ms;
|
|
ms.dwLength = sizeof(MEMORYSTATUS);
|
|
GlobalMemoryStatus(&ms);
|
|
|
|
Edit2->Text = AnsiString((double)ms.dwTotalPhys / 1024000.0) + " MB RAM";
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::ShowHelp(void)
|
|
{
|
|
Application->MessageBox("Usage: WinMySQLadmin.EXE [OPTIONS]\n\n-w Run the tool without start the Server.\n-h Shows this message and exit ", "WinMySQLadmin 1.0", MB_OK |MB_ICONINFORMATION);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::ContinueLoad(void)
|
|
{
|
|
OS->Text = TheOS();
|
|
Localhost->Text = TheComputer();
|
|
Localuser->Text = TheUser();
|
|
GetmemStatus();
|
|
ClearBox();
|
|
TakeIP();
|
|
MyODBC();
|
|
|
|
|
|
IsMyIniUp();
|
|
|
|
if (!NT) { WinNT->Enabled = false; NtVer->Enabled = false; Win9->Enabled = true; }
|
|
else { WinNT->Enabled = true; Win9->Enabled = false; }
|
|
|
|
if (i_start)
|
|
{
|
|
// NT never is started from the prompt
|
|
if ((!NT) && (!MySQLSignal())) mysqldstart();
|
|
{
|
|
TrayMessage(NIM_MODIFY);
|
|
SeekErrFile();
|
|
}
|
|
}
|
|
Hide();
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::MyODBC(void)
|
|
{
|
|
|
|
TRegistry *Registry = new TRegistry();
|
|
Memo3->Lines->Clear();
|
|
|
|
try
|
|
{
|
|
Registry->RootKey = HKEY_LOCAL_MACHINE;
|
|
// the basic data of myodbc
|
|
if (Registry->OpenKey("Software\\ODBC\\ODBCINST.INI\\MySQL", false))
|
|
{
|
|
Memo3->Lines->Add("Driver Version\t" + Registry->ReadString("DriverODBCVer"));
|
|
Memo3->Lines->Add("Driver\t\t" + Registry->ReadString("Driver"));
|
|
Memo3->Lines->Add("API Level\t\t" + Registry->ReadString("APILevel"));
|
|
Memo3->Lines->Add("Setup\t\t" + Registry->ReadString("Setup"));
|
|
Memo3->Lines->Add("SQL Level\t" + Registry->ReadString("SQLLevel"));
|
|
}
|
|
else
|
|
Memo3->Lines->Add("Not Found");
|
|
|
|
}
|
|
catch (...)
|
|
{
|
|
delete Registry;
|
|
}
|
|
Memo3->Enabled = false;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::IsMyIniUp(void)
|
|
{
|
|
// we see if the my.ini is Up
|
|
AnsiString asFileName = FileSearch("my.ini", TheWinDir());
|
|
if (asFileName.IsEmpty())
|
|
{
|
|
IsForce = true;
|
|
i_start = false;
|
|
QuickSearch();
|
|
}
|
|
else
|
|
{
|
|
Memo1->Enabled = true;
|
|
Memo1->Lines->Clear();
|
|
FillMyIni();
|
|
GetBaseDir();
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::QuickSearch(void)
|
|
{
|
|
AnsiString asFileName = FileSearch("mysql.exe", "c:/mysql/bin");
|
|
if (!asFileName.IsEmpty())
|
|
BaseDir->Text = "c:/mysql";
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
AnsiString __fastcall TForm1::TheWinDir()
|
|
{
|
|
AnsiString WinDir;
|
|
UINT BufferSize = GetWindowsDirectory(NULL,0);
|
|
WinDir.SetLength(BufferSize+1);
|
|
GetWindowsDirectory(WinDir.c_str(),BufferSize);
|
|
char* dirw = WinDir.c_str();
|
|
return dirw ;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::FillMyIni(void)
|
|
{
|
|
Memo1->Lines->LoadFromFile(TheWinDir() + "\\my.ini");
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::GetBaseDir(void)
|
|
{
|
|
|
|
char drive[_MAX_DRIVE];
|
|
char dir[_MAX_DIR];
|
|
char file[_MAX_FNAME];
|
|
char ext[_MAX_EXT];
|
|
|
|
|
|
TIniFile *pIniFile = new
|
|
TIniFile(TheWinDir() + "\\my.ini");
|
|
|
|
BaseDir->Text = pIniFile->ReadString("mysqld","basedir","") ;
|
|
AnsiString lx = pIniFile->ReadString("WinMySQLadmin","Server","") ;
|
|
_splitpath((lx).c_str(),drive,dir,file,ext);
|
|
AnsiString lw = (AnsiString) file + ext;
|
|
|
|
if ( lw == "mysqld-shareware.exe") {ShareVer->Checked = true;}
|
|
if ( lw == "mysqld.exe") {MysqldVer->Checked = true;}
|
|
if ( lw == "mysqld-opt.exe") {OptVer->Checked = true;}
|
|
if ( lw == "mysqld-nt.exe") {NtVer->Checked = true;}
|
|
|
|
delete pIniFile;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::Showme1Click(TObject *Sender)
|
|
{
|
|
if(Showme1->Caption == "Show me") { TrayMessage(NIM_DELETE);
|
|
Showme1->Caption = "Hide me"; Show(); }
|
|
else { TrayMessage(NIM_ADD); TrayMessage(NIM_MODIFY);
|
|
Showme1->Caption = "Show me"; Hide(); }
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::MySQLSignal()
|
|
{
|
|
HANDLE hEventShutdown;
|
|
hEventShutdown=OpenEvent(EVENT_MODIFY_STATE, 0, "MySqlShutdown");
|
|
|
|
if(hEventShutdown)
|
|
{
|
|
CloseHandle(hEventShutdown);
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
CloseHandle(hEventShutdown);
|
|
return false;
|
|
}
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::mysqldstart()
|
|
{
|
|
memset(&pi, 0, sizeof(pi));
|
|
memset(&si, 0, sizeof(si));
|
|
si.cb = sizeof(si);
|
|
si.dwFlags |= STARTF_USESHOWWINDOW;
|
|
si.wShowWindow |= SW_SHOWNORMAL;
|
|
|
|
|
|
TIniFile *pIniFile = new
|
|
TIniFile(TheWinDir() + "\\my.ini");
|
|
|
|
if (NT)
|
|
vpath = pIniFile->ReadString("WinMySQLadmin","Server","") + " --standalone\0" ;
|
|
else
|
|
vpath = pIniFile->ReadString("WinMySQLadmin","Server","") + "\0" ;
|
|
|
|
if ( ! CreateProcess(0,vpath.c_str(), 0, 0, 0, 0, 0, 0, &si,&pi))
|
|
{
|
|
TrayMessage(NIM_MODIFY);
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
TrayMessage(NIM_MODIFY);
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::SeekErrFile()
|
|
{
|
|
Memo4->Enabled = true;
|
|
Memo4->Lines->Clear();
|
|
AnsiString asFileName = FileSearch("mysql.err", BaseDir->Text + "/data");
|
|
if (!asFileName.IsEmpty())
|
|
{
|
|
FName = BaseDir->Text + "/data/mysql.err";
|
|
ifstream in((FName).c_str());
|
|
in.seekg(0, ios::end);
|
|
string s, line;
|
|
deque<string> v;
|
|
deque<string> lines;
|
|
streampos sp = in.tellg();
|
|
if (sp <= 1000)
|
|
in.seekg(0, ios::beg);
|
|
else
|
|
{
|
|
in.seekg(0, ios::beg);
|
|
in.seekg((sp - 1000));
|
|
}
|
|
|
|
do {
|
|
lines.push_back(line);
|
|
}while (getline(in, line));
|
|
|
|
|
|
if( lines.size() <= 15)
|
|
{
|
|
deque<string>::reverse_iterator r;
|
|
for(r = lines.rbegin(); r != lines.rend() ; r++)
|
|
{
|
|
if (ereport)
|
|
Memo5->Lines->Add((*r).c_str());
|
|
Memo4->Lines->Add((*r).c_str());
|
|
|
|
}
|
|
}
|
|
else
|
|
{
|
|
int k = 0;
|
|
deque<string>::reverse_iterator r;
|
|
for(r = lines.rbegin(); r != lines.rend(); r++)
|
|
{
|
|
if (ereport)
|
|
Memo5->Lines->Add((*r).c_str());
|
|
Memo4->Lines->Add((*r).c_str());
|
|
if (++k >= 15) { break;}
|
|
}
|
|
}
|
|
in.close();
|
|
return true;
|
|
}
|
|
else
|
|
return false;
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::Timer1Timer(TObject *Sender)
|
|
{
|
|
Showme1->Caption = "Show me";
|
|
TrayMessage(NIM_ADD);
|
|
TrayMessage(NIM_MODIFY);
|
|
Hide();
|
|
if (IsForce) {Form2->Show();}
|
|
Timer1->Enabled = false;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::GetServerFile()
|
|
{
|
|
|
|
AnsiString FileName;
|
|
|
|
if(!NT) {
|
|
FileName = FileSearch("mysqld-opt.exe", ExtractFilePath(Application->ExeName));
|
|
if (FileName.IsEmpty()) FileName = FileSearch("mysqld.exe", ExtractFilePath(Application->ExeName));
|
|
if (FileName.IsEmpty()) FileName = FileSearch("mysqld-shareware.exe", ExtractFilePath(Application->ExeName));
|
|
|
|
if (!FileName.IsEmpty()){
|
|
if ( FileName == "mysqld-opt.exe") {OptVer->Checked = true;}
|
|
if ( FileName == "mysqld.exe") {MysqldVer->Checked= true;}
|
|
if ( FileName == "mysqld-shareware.exe") {ShareVer->Checked= true;} }
|
|
|
|
}
|
|
else {
|
|
|
|
FileName = FileSearch("mysqld-nt.exe", ExtractFilePath(Application->ExeName));
|
|
if (FileName.IsEmpty()) FileName = FileSearch("mysqld.exe", ExtractFilePath(Application->ExeName));
|
|
if (FileName.IsEmpty()) FileName = FileSearch("mysqld-shareware.exe", ExtractFilePath(Application->ExeName));
|
|
|
|
if (!FileName.IsEmpty()) {
|
|
if ( FileName == "mysqld-nt.exe") {NtVer->Checked = true;}
|
|
if ( FileName == "mysqld.exe") {MysqldVer->Checked= true;}
|
|
if ( FileName == "mysqld-shareware.exe") {ShareVer->Checked= true;} }
|
|
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::CreateMyIniFile(void)
|
|
{
|
|
char szFileName[6];
|
|
int iFileHandle;
|
|
AnsiString jk;
|
|
|
|
Memo1->Enabled = true;
|
|
Memo1->Lines->Clear();
|
|
strcpy(szFileName,"\\my.ini");
|
|
iFileHandle = FileCreate(TheWinDir() + szFileName );
|
|
|
|
jk = "#This File was made using the WinMySQLadmin 1.0 Tool\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#" + Now() + "\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#Uncomment or Add only the keys that you know how works.\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#Read the MySQL Manual for instructions\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
|
|
jk = "[mysqld]\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "basedir=" + TheDir() + "\n";
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#bind-address=" + vip + "\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#datadir=" + TheDir() + "/data\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#language=" + TheDir() + "/share/your language directory\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#delay-key-write-for-all-tables\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#log-long-format\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#slow query log=#\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#tmpdir=#\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#ansi\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#new\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#port=3306\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#safe\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#skip-name-resolve\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#skip-networking\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#skip-new\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#skip-host-cache\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#set-variable = key_buffer=16M\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#set-variable = max_allowed_packet=1M\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#set-variable = thread_stack=128K\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#set-variable = flush_time=1800\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "[mysqldump]\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#quick\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#set-variable = max_allowed_packet=16M\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "[mysql]\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#no-auto-rehash\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "[isamchk]\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "#set-variable= key=16M\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "[WinMySQLadmin]\n\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
|
|
if (ShareVer->Checked) { jk = "Server=" + TheDir() + "/bin/mysqld-shareware.exe\n\n";}
|
|
if (MysqldVer->Checked) {jk = "Server=" + TheDir() + "/bin/mysqld.exe\n\n";}
|
|
if (OptVer->Checked) {jk = "Server=" + TheDir() + "/bin/mysqld-opt.exe\n\n";}
|
|
if (NtVer->Checked) {jk = "Server=" + TheDir() + "/bin/mysqld-nt.exe\n\n";}
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "user=" + Form2->Edit1->Text + "\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
jk = "password=" + Form2->Edit2->Text + "\n" ;
|
|
FileWrite(iFileHandle, (jk).c_str(), (jk).Length());
|
|
|
|
FileClose(iFileHandle);
|
|
FillMyIni();
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::CreatingShortCut()
|
|
{
|
|
// Where is The Start Menu in this Machine ?
|
|
LPITEMIDLIST pidl;
|
|
LPMALLOC pShellMalloc;
|
|
char szDir[MAX_PATH + 16];
|
|
AnsiString file;
|
|
AnsiString jk = "\\WinMySQLadmin.lnk" ;
|
|
|
|
if(SUCCEEDED(SHGetMalloc(&pShellMalloc)))
|
|
{
|
|
if(SUCCEEDED(SHGetSpecialFolderLocation(NULL,
|
|
CSIDL_STARTUP, &pidl)))
|
|
{
|
|
if(!SHGetPathFromIDList(pidl, szDir))
|
|
{
|
|
pShellMalloc->Release();
|
|
pShellMalloc->Free(pidl);
|
|
return false;
|
|
}
|
|
|
|
pShellMalloc->Free(pidl);
|
|
}
|
|
|
|
pShellMalloc->Release();
|
|
StrCat(szDir, jk.c_str());
|
|
}
|
|
|
|
// the create
|
|
|
|
IShellLink* pLink;
|
|
IPersistFile* pPersistFile;
|
|
|
|
if(SUCCEEDED(CoInitialize(NULL)))
|
|
{
|
|
if(SUCCEEDED(CoCreateInstance(CLSID_ShellLink, NULL,
|
|
CLSCTX_INPROC_SERVER,
|
|
IID_IShellLink, (void **) &pLink)))
|
|
{
|
|
|
|
pLink->SetPath((ExtractFilePath(Application->ExeName) + "WinMySQLadmin.exe").c_str());
|
|
pLink->SetDescription("WinMySQLadmin Tool");
|
|
pLink->SetShowCmd(SW_SHOW);
|
|
|
|
if(SUCCEEDED(pLink->QueryInterface(IID_IPersistFile,
|
|
(void **)&pPersistFile)))
|
|
{
|
|
|
|
WideString strShortCutLocation(szDir);
|
|
pPersistFile->Save(strShortCutLocation.c_bstr(), TRUE);
|
|
pPersistFile->Release();
|
|
}
|
|
pLink->Release();
|
|
}
|
|
|
|
CoUninitialize();
|
|
}
|
|
|
|
|
|
return true;
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
AnsiString __fastcall TForm1::TheDir()
|
|
{
|
|
AnsiString buffer;
|
|
char s[_MAX_PATH + 1];
|
|
|
|
StrCopy(s, ( BaseDir->Text).c_str()) ;
|
|
|
|
for (int i = 0; s[i] != NULL; i++)
|
|
if (s[i] != '\\')
|
|
buffer += s[i];
|
|
else
|
|
buffer += "/";
|
|
|
|
return buffer;
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::SpeedButton1Click(TObject *Sender)
|
|
{
|
|
Application->HelpCommand(HELP_FINDER,0);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Timer2Timer(TObject *Sender)
|
|
{
|
|
ToggleState();
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::TheServiceStart()
|
|
{
|
|
bool thatok;
|
|
char *SERVICE_NAME = "MySql";
|
|
SC_HANDLE myService, scm;
|
|
scm = OpenSCManager(0, 0, SC_MANAGER_ALL_ACCESS | GENERIC_WRITE);
|
|
if (scm)
|
|
{
|
|
myService = OpenService(scm, SERVICE_NAME, SERVICE_ALL_ACCESS);
|
|
if (myService)
|
|
thatok = true;
|
|
else
|
|
thatok = false;
|
|
}
|
|
CloseServiceHandle(myService);
|
|
CloseServiceHandle(scm);
|
|
return thatok;
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::TheServicePause()
|
|
{
|
|
|
|
bool thatok;
|
|
char *SERVICE_NAME = "MySql";
|
|
SC_HANDLE myService, scm;
|
|
scm = OpenSCManager(0, 0, SC_MANAGER_ALL_ACCESS);
|
|
|
|
if (scm)
|
|
{
|
|
myService = OpenService(scm, SERVICE_NAME, SERVICE_ALL_ACCESS);
|
|
if (myService)
|
|
{
|
|
// stop the service
|
|
if (IsConnect)
|
|
{
|
|
mysql_kill(MySQL,mysql_thread_id(MySQL));
|
|
StatusLine->SimpleText = "";
|
|
q = 0;
|
|
}
|
|
|
|
|
|
SERVICE_STATUS ss;
|
|
thatok = ControlService(myService,
|
|
SERVICE_CONTROL_STOP,
|
|
&ss);
|
|
|
|
}
|
|
else
|
|
thatok = false;
|
|
}
|
|
else
|
|
thatok = false;
|
|
|
|
CloseServiceHandle(myService);
|
|
CloseServiceHandle(scm);
|
|
return thatok;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::TheServiceResume()
|
|
{
|
|
|
|
bool thatok;
|
|
char *SERVICE_NAME = "MySql";
|
|
SC_HANDLE myService, scm;
|
|
scm = OpenSCManager(0, 0, SC_MANAGER_ALL_ACCESS);
|
|
|
|
if (scm)
|
|
{
|
|
myService = OpenService(scm, SERVICE_NAME, SERVICE_ALL_ACCESS);
|
|
if (myService)
|
|
{
|
|
// start the service
|
|
|
|
thatok = StartService(myService, 0, NULL);
|
|
}
|
|
else
|
|
thatok = false;
|
|
}
|
|
else
|
|
thatok = false;
|
|
|
|
CloseServiceHandle(myService);
|
|
CloseServiceHandle(scm);
|
|
return thatok;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::TheServiceStatus()
|
|
{
|
|
bool thatok;
|
|
bool k;
|
|
char *SERVICE_NAME = "MySql";
|
|
SC_HANDLE myService, scm;
|
|
SERVICE_STATUS ss;
|
|
DWORD dwState = 0xFFFFFFFF;
|
|
scm = OpenSCManager(0, 0, SC_MANAGER_ALL_ACCESS);
|
|
|
|
if (scm)
|
|
{
|
|
myService = OpenService(scm, SERVICE_NAME, SERVICE_ALL_ACCESS);
|
|
if (myService)
|
|
{
|
|
memset(&ss, 0, sizeof(ss));
|
|
k = QueryServiceStatus(myService,&ss);
|
|
if (k)
|
|
{
|
|
dwState = ss.dwCurrentState;
|
|
if (dwState == SERVICE_RUNNING)
|
|
thatok = true;
|
|
}
|
|
else
|
|
thatok = false;
|
|
}
|
|
else
|
|
thatok = false;
|
|
}
|
|
else
|
|
thatok = false;
|
|
|
|
CloseServiceHandle(myService);
|
|
CloseServiceHandle(scm);
|
|
return thatok;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::TheServiceCreate()
|
|
|
|
{
|
|
bool thatok;
|
|
char *SERVICE_NAME = "MySql";
|
|
char *szFullPath = vpath.c_str();
|
|
SC_HANDLE myService, scm;
|
|
scm = OpenSCManager(0, 0, SC_MANAGER_ALL_ACCESS);
|
|
|
|
if (scm)
|
|
{ myService = CreateService(
|
|
scm,
|
|
SERVICE_NAME,
|
|
SERVICE_NAME,
|
|
SERVICE_ALL_ACCESS,
|
|
SERVICE_WIN32_OWN_PROCESS,
|
|
SERVICE_AUTO_START ,
|
|
SERVICE_ERROR_NORMAL,
|
|
szFullPath,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL,
|
|
NULL);
|
|
|
|
if (myService)
|
|
thatok = true;
|
|
else
|
|
thatok = false;
|
|
|
|
}
|
|
|
|
CloseServiceHandle(myService);
|
|
CloseServiceHandle(scm);
|
|
return thatok;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Swin9Click(TObject *Sender)
|
|
{
|
|
if(Application->MessageBox("Shutdown this tool", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
Close();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SSW9Click(TObject *Sender)
|
|
{
|
|
if (MySQLSignal())
|
|
{
|
|
if(Application->MessageBox("Shutdown the MySQL Server ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
|
|
if (Shutd())
|
|
{
|
|
IsConnect = false;
|
|
IsVariables = false;
|
|
IsProcess = false;
|
|
IsDatabases = false;
|
|
ya = false;
|
|
ClearBox();
|
|
Sleep(500);
|
|
TrayMessage(NIM_MODIFY);
|
|
|
|
}
|
|
else
|
|
Application->MessageBox("Fails to Shutdown the Server", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(Application->MessageBox("Start the MySQL Server ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
if (mysqldstart())
|
|
{
|
|
TrayMessage(NIM_MODIFY);
|
|
ya = true;
|
|
}
|
|
else
|
|
Application->MessageBox("Fails to Start the Server", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
|
|
}
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::ShutDownBoth1Click(TObject *Sender)
|
|
{
|
|
if (MySQLSignal())
|
|
{
|
|
if(Application->MessageBox("Shutdown the MySQL Server and this tool ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
|
|
if (Shutd())
|
|
Close();
|
|
else
|
|
{
|
|
Application->MessageBox("Fails to Shutdown the Server", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
|
|
}
|
|
}
|
|
}
|
|
else
|
|
if(Application->MessageBox("Shutdown this tool ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
Close();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::ShutDownthisTool1Click(TObject *Sender)
|
|
{
|
|
if(Application->MessageBox("Shutdown this tool ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
Close();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::StopSClick(TObject *Sender)
|
|
{
|
|
AnsiString theWarning;
|
|
theWarning = "Are you sure to stop the Service ?\n\nAll the connections will be loss !" ;
|
|
if (TheServiceStatus())
|
|
{
|
|
if(Application->MessageBox(theWarning.c_str(), "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
if (TheServicePause())
|
|
{
|
|
TrayMessage(NIM_MODIFY);
|
|
IsConnect = false;
|
|
IsVariables = false;
|
|
IsProcess = false;
|
|
IsDatabases = false;
|
|
ya = false;
|
|
ClearBox();
|
|
|
|
}
|
|
else
|
|
Application->MessageBox("Fails to stop the Service", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(Application->MessageBox("Start the Service Manager for the MySQL Server ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
if (TheServiceResume())
|
|
{
|
|
ya = true;
|
|
TrayMessage(NIM_MODIFY);
|
|
}
|
|
else
|
|
Application->MessageBox("Fails to start the Service", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::RServiceClick(TObject *Sender)
|
|
{
|
|
if (TheServiceStart())
|
|
{
|
|
if(Application->MessageBox("Remove the MySQL Server service ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
if (!TheServiceRemove())
|
|
Application->MessageBox("Fails to Remove The MySQL Server Service", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(Application->MessageBox("Install the MySQL Server service ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
if (!TheServerPath())
|
|
Application->MessageBox("Please create first the my.ini setup", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
else
|
|
{
|
|
if (!TheServiceCreate())
|
|
Application->MessageBox("Fails to Install The MySQL Server Service", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
|
|
}
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::StandaClick(TObject *Sender)
|
|
{
|
|
if (MySQLSignal())
|
|
{
|
|
if(Application->MessageBox("Shutdown the MySQL Server ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
if (Shutd())
|
|
{
|
|
IsConnect = false;
|
|
IsVariables = false;
|
|
IsProcess = false;
|
|
IsDatabases = false;
|
|
ya = false;
|
|
ClearBox();
|
|
Sleep(500);
|
|
TrayMessage(NIM_MODIFY);
|
|
|
|
}
|
|
else
|
|
Application->MessageBox("Fails to Shutdown the Server", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(Application->MessageBox("Start the MySQL Server ", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
if (mysqldstart())
|
|
{
|
|
StatusLine->SimpleText = "";
|
|
TrayMessage(NIM_MODIFY);
|
|
|
|
}
|
|
else
|
|
Application->MessageBox("Fails to Start the Server", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::Shutd()
|
|
{
|
|
// from Irena
|
|
HANDLE hEventShutdown;
|
|
hEventShutdown=OpenEvent(EVENT_MODIFY_STATE, 0, "MySqlShutdown");
|
|
|
|
if (IsConnect)
|
|
{
|
|
mysql_kill(MySQL,mysql_thread_id(MySQL));
|
|
mysql_shutdown(MySQL, SHUTDOWN_DEFAULT);
|
|
StatusLine->SimpleText = "";
|
|
|
|
}
|
|
|
|
q = 0;
|
|
|
|
|
|
if(hEventShutdown)
|
|
{
|
|
SetEvent(hEventShutdown);
|
|
CloseHandle(hEventShutdown);
|
|
TrayMessage(NIM_MODIFY);
|
|
IsConnect = false;
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
TrayMessage(NIM_MODIFY);
|
|
return false;
|
|
}
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::ClearBox(void)
|
|
{
|
|
|
|
st22->Text = "";
|
|
st23->Text = "";
|
|
st24->Text = "";
|
|
st25->Text = "";
|
|
st26->Text = "";
|
|
st27->Text = "";
|
|
st28->Text = "";
|
|
st29->Text = "";
|
|
Edit3->Text = "";
|
|
Edit4->Text = "";
|
|
Edit5->Text = "";
|
|
Edit6->Text = "";
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::TheServiceRemove()
|
|
{
|
|
bool thatok;
|
|
char *SERVICE_NAME = "MySql";
|
|
SC_HANDLE myService, scm;
|
|
scm = OpenSCManager(0, 0, SC_MANAGER_ALL_ACCESS);
|
|
if (scm)
|
|
{
|
|
myService = OpenService(scm, SERVICE_NAME, SERVICE_ALL_ACCESS);
|
|
if (myService)
|
|
{
|
|
if(DeleteService(myService))
|
|
{
|
|
CloseServiceHandle(myService);
|
|
CloseServiceHandle(scm);
|
|
thatok = true;
|
|
}
|
|
else
|
|
{
|
|
CloseServiceHandle(myService);
|
|
CloseServiceHandle(scm);
|
|
thatok = false;
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
CloseServiceHandle(myService);
|
|
CloseServiceHandle(scm);
|
|
thatok = false;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
thatok = false;
|
|
CloseServiceHandle(scm);
|
|
}
|
|
|
|
return thatok;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::TheServerPath()
|
|
{
|
|
|
|
TIniFile *pIniFile = new
|
|
TIniFile(TheWinDir() + "\\my.ini");
|
|
|
|
vpath = pIniFile->ReadString("WinMySQLadmin","Server","") ;
|
|
delete pIniFile;
|
|
if (vpath.IsEmpty())
|
|
return false;
|
|
else
|
|
return true;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button5Click(TObject *Sender)
|
|
{
|
|
if (!SeekErrFile())
|
|
Application->MessageBox("Fails to find mysql.err", "WinMySQLadmin 1.0", MB_OK |MB_ICONINFORMATION);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::IsMySQLInit(void)
|
|
{
|
|
AnsiString theCommand;
|
|
char *host = NULL,*password=0,*user=0 ;
|
|
TIniFile *pIniFile = new
|
|
TIniFile(TheWinDir() + "\\my.ini");
|
|
|
|
AnsiString MyUser = pIniFile->ReadString("WinMySQLadmin","user","") ;
|
|
AnsiString MyPass = pIniFile->ReadString("WinMySQLadmin","password","") ;
|
|
|
|
delete pIniFile;
|
|
|
|
|
|
if (!MyUser.IsEmpty() && MyUser.Length() && !MyPass.IsEmpty() && MyPass.Length())
|
|
{
|
|
if (!IsConnect)
|
|
{
|
|
|
|
MySQL = mysql_init(MySQL);
|
|
if (mysql_real_connect(MySQL, "localhost",(MyUser).c_str(), (MyPass).c_str() , 0, 0, NULL, 0))
|
|
IsConnect = true;
|
|
else
|
|
{
|
|
if(mysql_real_connect(MySQL,host,user,password , 0, 0, NULL, 0))
|
|
{
|
|
IsConnect = true;
|
|
theCommand = "GRANT ALL PRIVILEGES ON *.* TO ";
|
|
theCommand += "'" + MyUser + "' @localhost IDENTIFIED BY ";
|
|
theCommand += "'" + MyPass + "' with GRANT OPTION";
|
|
char* los = theCommand.c_str();
|
|
if(!mysql_query(MySQL, los ))
|
|
StatusLine->SimpleText = " ";
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
if (!IsConnect)
|
|
{
|
|
MySQL = mysql_init(MySQL);
|
|
if(mysql_real_connect(MySQL,host,user,password , 0, 0, NULL, 0))
|
|
IsConnect = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Timer3Timer(TObject *Sender)
|
|
{
|
|
if ((NT) && TheServiceStatus()) {IsMySQLInit(); }
|
|
|
|
if ((NT) && !TheServiceStatus() && MySQLSignal()) {IsMySQLInit(); }
|
|
|
|
if (!(NT) && MySQLSignal()) {IsMySQLInit(); }
|
|
|
|
if (IsConnect)
|
|
{
|
|
GetServerStatus();
|
|
if (!IsMySQLNode)
|
|
GetMainRoot();
|
|
Extended->Enabled = true;
|
|
if (!IsProcess && !GetProcess())
|
|
StatusLine->SimpleText = "";
|
|
if (!IsVariables && !GetVariables())
|
|
StatusLine->SimpleText = "";
|
|
Timer3->Interval = 10000;
|
|
}
|
|
else
|
|
Extended->Enabled = false;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::GetServerStatus(void)
|
|
{
|
|
|
|
GetExtendedStatus();
|
|
Edit3->Text = mysql_get_server_info(MySQL);
|
|
Edit4->Text = mysql_get_host_info(MySQL);
|
|
Edit5->Text = mysql_get_client_info();
|
|
Edit6->Text = mysql_get_proto_info(MySQL);
|
|
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::GetProcess()
|
|
{
|
|
MYSQL_RES *res;
|
|
MYSQL_ROW row;
|
|
unsigned int i;
|
|
int k = 0;
|
|
int therow = 1;
|
|
new_line=1;
|
|
|
|
StringGrid2->RowCount= 2;
|
|
|
|
if (!(res=mysql_list_processes(MySQL)))
|
|
{
|
|
return false;
|
|
}
|
|
|
|
while ((row=mysql_fetch_row(res)) != 0)
|
|
{
|
|
mysql_field_seek(res,0);
|
|
StringGrid2->Cells[0][0] = "PID";
|
|
StringGrid2->Cells[1][0] = "User";
|
|
StringGrid2->Cells[2][0] = "Host";
|
|
StringGrid2->Cells[3][0] = "DB";
|
|
StringGrid2->Cells[4][0] = "Command";
|
|
StringGrid2->Cells[5][0] = "Time";
|
|
StringGrid2->Cells[6][0] = "State";
|
|
StringGrid2->Cells[7][0] = "Info";
|
|
for (i=0 ; i < mysql_num_fields(res); i++)
|
|
{
|
|
|
|
if (k <= 6 )
|
|
{
|
|
StringGrid2->Cells[k][therow] = row[i];
|
|
k++;
|
|
}
|
|
else
|
|
{
|
|
|
|
StringGrid2->Cells[(k)][therow] = row[i];
|
|
k = 0;
|
|
therow++ ;
|
|
StringGrid2->RowCount++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
StringGrid2->RowCount--;
|
|
mysql_free_result(res);
|
|
StringGrid5->RowCount--;
|
|
IsProcess = true;
|
|
return true;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::GetVariables()
|
|
{
|
|
MYSQL_RES *res;
|
|
MYSQL_ROW row;
|
|
unsigned int i;
|
|
int k = 1;
|
|
new_line=1;
|
|
bool left = true;
|
|
AnsiString report;
|
|
StringGrid1->RowCount = 2;
|
|
if (mysql_query(MySQL,"show variables") ||
|
|
!(res=mysql_store_result(MySQL)))
|
|
{
|
|
return false;
|
|
}
|
|
|
|
while ((row=mysql_fetch_row(res)) != 0)
|
|
{
|
|
mysql_field_seek(res,0);
|
|
|
|
StringGrid1->Cells[0][0] = "Variable Name";
|
|
StringGrid1->Cells[1][0] = "Value";
|
|
|
|
|
|
for (i=0 ; i < mysql_num_fields(res); i++)
|
|
{
|
|
|
|
if (left)
|
|
{
|
|
if (treport)
|
|
report = GetString(row[i]);
|
|
StringGrid1->Cells[0][k++] = row[i];
|
|
left = false;
|
|
}
|
|
else
|
|
{
|
|
if (treport)
|
|
Memo5->Lines->Add(report + row[i]);
|
|
StringGrid1->RowCount++;
|
|
StringGrid1->Cells[1][--k] = row[i];
|
|
k++;
|
|
left = true;
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
StringGrid1->RowCount--;
|
|
mysql_free_result(res);
|
|
IsVariables = true;
|
|
return true;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::nice_time(AnsiString buff)
|
|
{
|
|
|
|
unsigned long sec;
|
|
unsigned long tmp;
|
|
AnsiString mytime;
|
|
|
|
sec = StrToInt(buff);
|
|
|
|
if (sec >= 3600L*24)
|
|
{
|
|
tmp=sec/(3600L*24);
|
|
sec-=3600L*24*tmp;
|
|
|
|
mytime = IntToStr(tmp);
|
|
if (tmp > 1)
|
|
mytime+= " days ";
|
|
else
|
|
mytime+= " day ";
|
|
|
|
}
|
|
|
|
if (sec >= 3600L)
|
|
{
|
|
tmp=sec/3600L;
|
|
sec-=3600L*tmp;
|
|
mytime += IntToStr(tmp);
|
|
if (tmp > 1)
|
|
mytime+= " hours ";
|
|
else
|
|
mytime+= " hour ";
|
|
}
|
|
if (sec >= 60)
|
|
{
|
|
tmp=sec/60;
|
|
sec-=60*tmp;
|
|
mytime += IntToStr(tmp);
|
|
mytime+= " min ";
|
|
|
|
}
|
|
mytime += IntToStr(sec);
|
|
mytime+= " sec ";
|
|
st29->Text = mytime ;
|
|
return true;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::Button11Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (GetVariables())
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button10Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (GetProcess())
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button6Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (mysql_refresh(MySQL,REFRESH_HOSTS))
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button7Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (mysql_refresh(MySQL,REFRESH_LOG))
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button8Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (mysql_refresh(MySQL,REFRESH_TABLES))
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button2Click(TObject *Sender)
|
|
{
|
|
Memo1->Enabled = true;
|
|
Memo1->Lines->Clear();
|
|
AnsiString asFileName = FileSearch("my.ini", TheWinDir());
|
|
if (asFileName.IsEmpty())
|
|
Application->MessageBox("Don't found my.ini file on the Win Directory", "WinMySQLadmin 1.0", MB_OK |MB_ICONINFORMATION);
|
|
else
|
|
FillMyIni();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button3Click(TObject *Sender)
|
|
{
|
|
TIniFile *pIniFile = new
|
|
TIniFile(TheWinDir() + "\\my.ini");
|
|
|
|
if (!Memo1->GetTextLen())
|
|
Application->MessageBox("The Memo Box is Empty", "WinMySQLadmin 1.0", MB_OK |MB_ICONINFORMATION);
|
|
else
|
|
{
|
|
if(Application->MessageBox("Are you sure to write the modifications into My.ini file.", "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
Memo1->Lines->SaveToFile(TheWinDir() + "\\my.ini");
|
|
|
|
Memo1->Lines->Clear();
|
|
Memo1->Enabled = true;
|
|
Memo1->Lines->Clear();
|
|
if (NtVer->Checked)
|
|
pIniFile->WriteString("WinMySQLadmin","Server",TheDir() + "/bin/mysqld-nt.exe");
|
|
if (MysqldVer->Checked == true)
|
|
pIniFile->WriteString("WinMySQLadmin","Server", TheDir() + "/bin/mysqld.exe");
|
|
if (ShareVer->Checked)
|
|
pIniFile->WriteString("WinMySQLadmin","Server",TheDir() + "/bin/mysqld-shareware.exe");
|
|
if (OptVer->Checked)
|
|
pIniFile->WriteString("WinMySQLadmin","Server", TheDir() + "/bin/mysqld-opt.exe");
|
|
FillMyIni();
|
|
Application->MessageBox("My.ini was modificated", "WinMySQLadmin 1.0", MB_OK |MB_ICONINFORMATION);
|
|
}
|
|
|
|
}
|
|
delete pIniFile;
|
|
Memo1->Lines->Clear();
|
|
FillMyIni();
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button1Click(TObject *Sender)
|
|
{
|
|
if(CreatingShortCut())
|
|
Application->MessageBox("The ShortCut on Start Menu was created", "WinMySQLadmin 1.0", MB_OK |MB_ICONINFORMATION);
|
|
else
|
|
Application->MessageBox("Fails the Operation of Create the ShortCut", "WinMySQLadmin 1.0", MB_OK |MB_ICONINFORMATION);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SpeedButton2Click(TObject *Sender)
|
|
{
|
|
BROWSEINFO info;
|
|
char szDir[MAX_PATH];
|
|
char szDisplayName[MAX_PATH];
|
|
LPITEMIDLIST pidl;
|
|
LPMALLOC pShellMalloc;
|
|
|
|
|
|
if(SHGetMalloc(&pShellMalloc) == NO_ERROR)
|
|
{
|
|
|
|
memset(&info, 0x00,sizeof(info));
|
|
info.hwndOwner = Handle;
|
|
info.pidlRoot = 0;
|
|
info.pszDisplayName = szDisplayName;
|
|
info.lpszTitle = "Search MySQL Base Directory";
|
|
info.ulFlags = BIF_RETURNONLYFSDIRS;
|
|
info.lpfn = 0;
|
|
|
|
pidl = SHBrowseForFolder(&info);
|
|
|
|
if(pidl)
|
|
{
|
|
|
|
if(SHGetPathFromIDList(pidl, szDir)) {BaseDir->Text = szDir; }
|
|
|
|
pShellMalloc->Free(pidl);
|
|
}
|
|
pShellMalloc->Release();
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::Button4Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
Memo3->Lines->Add(mysql_stat(MySQL));
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
void __fastcall TForm1::SpeedButton3Click(TObject *Sender)
|
|
{
|
|
if(Showme1->Caption == "Show me") { TrayMessage(NIM_DELETE);
|
|
Showme1->Caption = "Hide me"; Show(); }
|
|
else { TrayMessage(NIM_ADD); TrayMessage(NIM_MODIFY);
|
|
Showme1->Caption = "Show me"; Hide(); }
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::ExtendedClick(TObject *Sender)
|
|
{
|
|
if (ya)
|
|
{
|
|
Extended->Caption = "Start Extended Server Status";
|
|
ya = false;
|
|
ClearBox();
|
|
}
|
|
else
|
|
{
|
|
Extended->Caption = "Stop Extended Server Status";
|
|
ya = true;
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::GetServerOptions(void)
|
|
{
|
|
AnsiString FileName;
|
|
FileName = FileSearch("mysqld-opt.exe", ExtractFilePath(Application->ExeName));
|
|
if (FileName.IsEmpty()) {OptVer->Enabled = false; }
|
|
|
|
FileName = FileSearch("mysqld-shareware.exe", ExtractFilePath(Application->ExeName));
|
|
if (FileName.IsEmpty()) {ShareVer->Enabled = false; }
|
|
|
|
FileName = FileSearch("mysqld.exe", ExtractFilePath(Application->ExeName));
|
|
if (FileName.IsEmpty()) {MysqldVer->Enabled = false; }
|
|
|
|
FileName = FileSearch("mysqld-nt.exe", ExtractFilePath(Application->ExeName));
|
|
if (FileName.IsEmpty()) {NtVer->Enabled = false; }
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::GetReportServer(void)
|
|
{
|
|
|
|
AnsiString strspace;
|
|
Memo5->Lines->Clear();
|
|
Memo5->Lines->Add("This Report was made using the WinMySQLadmin 1.0 Tool");
|
|
Memo5->Lines->Add("");
|
|
Memo5->Lines->Add(Now());
|
|
Memo5->Lines->Add("");
|
|
|
|
preport = true;
|
|
Memo5->Lines->Add("");
|
|
Memo5->Lines->Add("Server Status Values");
|
|
Memo5->Lines->Add("");
|
|
Memo5->Lines->Add(GetString("Server Info") + mysql_get_server_info(MySQL));
|
|
Memo5->Lines->Add(GetString("Host Info") + mysql_get_host_info(MySQL));
|
|
Memo5->Lines->Add(GetString("Client Info") + mysql_get_client_info());
|
|
Memo5->Lines->Add(GetString("Proto Info") + mysql_get_proto_info(MySQL));
|
|
GetExtendedStatus();
|
|
preport = false;
|
|
treport = true;
|
|
Memo5->Lines->Add("");
|
|
Memo5->Lines->Add("Variables Values");
|
|
Memo5->Lines->Add("");
|
|
GetVariables();
|
|
treport = false;
|
|
ereport = true;
|
|
Memo5->Lines->Add("");
|
|
Memo5->Lines->Add("Last Lines from Err File");
|
|
Memo5->Lines->Add("");
|
|
SeekErrFile();
|
|
ereport = false;
|
|
|
|
}
|
|
|
|
void __fastcall TForm1::SpeedButton4Click(TObject *Sender)
|
|
{
|
|
if(IsConnect)
|
|
GetReportServer();
|
|
else
|
|
Application->MessageBox("The Server must be connected", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SpeedButton5Click(TObject *Sender)
|
|
{
|
|
AnsiString PathName;
|
|
SaveFileDialog->FileName = PathName;
|
|
if (SaveFileDialog->Execute() ){
|
|
PathName= SaveFileDialog->FileName;
|
|
Caption = ExtractFileName(PathName);
|
|
Memo5->Lines->SaveToFile(PathName);
|
|
Memo5->Modified = false;
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
String __fastcall TForm1::GetString(String k)
|
|
{
|
|
int i = 35 - k.Length();
|
|
for (int y = 1 ; y <= i ;y++ )
|
|
k+= " ";
|
|
return k ;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::SpeedButton6Click(TObject *Sender)
|
|
{
|
|
PrinterSetupDialog1->Execute();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SpeedButton7Click(TObject *Sender)
|
|
{
|
|
AnsiString PathName;
|
|
if (PrintDialog1->Execute()){
|
|
try {
|
|
Memo5->Print(PathName);
|
|
}
|
|
catch(...){
|
|
Printer()->EndDoc();
|
|
throw;
|
|
}
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SpeedButton8Click(TObject *Sender)
|
|
{
|
|
Memo5->CutToClipboard();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SpeedButton9Click(TObject *Sender)
|
|
{
|
|
Memo5->CopyToClipboard();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SpeedButton10Click(TObject *Sender)
|
|
{
|
|
|
|
Memo5->PasteFromClipboard();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SpeedButton11Click(TObject *Sender)
|
|
{
|
|
Memo5->ClearSelection();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::SpeedButton12Click(TObject *Sender)
|
|
{
|
|
Memo5->SelectAll();
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::GetMainRoot()
|
|
{
|
|
|
|
MYSQL_RES *res;
|
|
MYSQL_ROW row;
|
|
unsigned int i;
|
|
AnsiString command;
|
|
|
|
CleanGrid();
|
|
CleanGridI();
|
|
TakeIP();
|
|
|
|
MySQLNode = DBView->Items->Add(NULL, mainroot.UpperCase());
|
|
MySQLNode->ImageIndex = 0;
|
|
|
|
if (!(res=mysql_list_dbs(MySQL,"%"))) { return false; }
|
|
while ((row=mysql_fetch_row(res)) != 0) {
|
|
mysql_field_seek(res,0);
|
|
|
|
for (i=0 ; i < mysql_num_fields(res); i++)
|
|
{
|
|
MySQLDbs = DBView->Items->AddChild(MySQLNode, row[i]);
|
|
MySQLDbs->ImageIndex = 1;
|
|
MySQLDbs->SelectedIndex = 1;
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
mysql_free_result(res);
|
|
MySQLNode->Expanded = true;
|
|
|
|
|
|
|
|
|
|
IsMySQLNode = true;
|
|
return true;
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::DeleteDatabaseSClick(TObject *Sender)
|
|
{
|
|
AnsiString alert;
|
|
if (IsConnect)
|
|
{
|
|
if(DBView->Selected == MySQLNode )
|
|
Application->MessageBox("Invalid database row selected.", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
else if ( DBView->Selected == NULL )
|
|
Application->MessageBox("Invalid database row selected.", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
else
|
|
{
|
|
if (DBView->Selected->Text.UpperCase() == "MYSQL")
|
|
Application->MessageBox("You cann't use this tool to drop the MySQL Database.", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
else {
|
|
alert = "Are you sure to drop the < ";
|
|
alert+= DBView->Selected->Text.c_str();
|
|
alert+= " > database.";
|
|
if(Application->MessageBox(alert.c_str(), "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
char* lese = DBView->Selected->Text.c_str();
|
|
if (!mysql_drop_db(MySQL, lese ))
|
|
{
|
|
DBView->Items->Clear();
|
|
GetMainRoot();
|
|
}
|
|
else
|
|
Application->MessageBox("Fails to drop the Database.", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else
|
|
Application->MessageBox("The Server must be connected", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::IsDatabase(String Name)
|
|
{
|
|
MYSQL_RES *res;
|
|
MYSQL_ROW row;
|
|
unsigned int i;
|
|
AnsiString command;
|
|
|
|
|
|
CleanTree();
|
|
command = "use ";
|
|
command+= Name.c_str();
|
|
char* das = command.c_str();
|
|
char* lis = Name.c_str();
|
|
if (mysql_query(MySQL, das ) ||
|
|
!(res=mysql_list_tables(MySQL,"%")))
|
|
return false;
|
|
|
|
MySQLNodeT = TableView->Items->Add(NULL, lis);
|
|
MySQLNodeT->ImageIndex = 1;
|
|
MySQLNodeT->SelectedIndex = 1;
|
|
while ((row=mysql_fetch_row(res)) != 0) {
|
|
mysql_field_seek(res,0);
|
|
|
|
for (i=0 ; i < mysql_num_fields(res); i++)
|
|
{
|
|
|
|
MySQLTbs = TableView->Items->AddChild(MySQLNodeT, row[i]);
|
|
MySQLTbs->ImageIndex = 2;
|
|
MySQLTbs->SelectedIndex = 2;
|
|
}
|
|
MySQLNodeT->Expanded = true;
|
|
}
|
|
mysql_free_result(res);
|
|
return true;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
void __fastcall TForm1::DBViewClick(TObject *Sender)
|
|
{
|
|
|
|
if (IsConnect)
|
|
{
|
|
if (DBView->Selected != MySQLNode && DBView->Selected != NULL )
|
|
{
|
|
IsDatabase(DBView->Selected->Text);
|
|
|
|
}
|
|
else
|
|
{
|
|
CleanTree();
|
|
}
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::TableViewClick(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (DBView->Selected != MySQLNodeT )
|
|
{
|
|
IsTable(TableView->Selected->Text);
|
|
IsIndex(TableView->Selected->Text);
|
|
|
|
}
|
|
else
|
|
{
|
|
CleanGrid();
|
|
CleanGridI();
|
|
|
|
}
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::IsTable(String Name)
|
|
{
|
|
MYSQL_RES *res;
|
|
MYSQL_ROW row;
|
|
unsigned int i;
|
|
int k = 0;
|
|
int therow = 1;
|
|
new_line=1;
|
|
AnsiString command;
|
|
AnsiString commandt;
|
|
|
|
CleanGrid();
|
|
CleanGridI();
|
|
command = "use ";
|
|
command+= DBView->Selected->Text.c_str();
|
|
char* las = command.c_str();
|
|
|
|
commandt = "desc ";
|
|
commandt+= Name.c_str();
|
|
char* les = commandt.c_str();
|
|
|
|
if (mysql_query(MySQL, las ))
|
|
return false;
|
|
|
|
if (mysql_query(MySQL, les ) ||
|
|
!(res=mysql_store_result(MySQL)))
|
|
return false ;
|
|
|
|
StringGrid4->Cells[0][0] = "Field";
|
|
StringGrid4->Cells[1][0] = "Type";
|
|
StringGrid4->Cells[2][0] = "Null";
|
|
StringGrid4->Cells[3][0] = "Key";
|
|
StringGrid4->Cells[4][0] = "Default";
|
|
StringGrid4->Cells[5][0] = "Extra";
|
|
StringGrid4->Cells[6][0] = "Previleges";
|
|
|
|
|
|
int thecounter;
|
|
String u = GetNumberServer();
|
|
if ( u == "3.22")
|
|
{
|
|
StringGrid3->ColCount = 7;
|
|
thecounter = 4;
|
|
}
|
|
else
|
|
thecounter = 5;
|
|
|
|
while ((row=mysql_fetch_row(res)) != 0)
|
|
{
|
|
mysql_field_seek(res,0);
|
|
|
|
for (i=0 ; i < mysql_num_fields(res); i++)
|
|
{
|
|
if (k <= thecounter )
|
|
{
|
|
StringGrid4->Cells[k][therow] = row[i];
|
|
k++;
|
|
}
|
|
else
|
|
{
|
|
StringGrid4->Cells[(k)][therow] = row[i];
|
|
k = 0;
|
|
therow++ ;
|
|
StringGrid4->RowCount++;
|
|
}
|
|
}
|
|
|
|
}
|
|
StringGrid4->RowCount--;
|
|
mysql_free_result(res);
|
|
return true;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::TableViewChange(TObject *Sender, TTreeNode *Node)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (DBView->Selected != MySQLNodeT )
|
|
{
|
|
IsTable(TableView->Selected->Text);
|
|
IsIndex(TableView->Selected->Text);
|
|
|
|
}
|
|
else
|
|
{
|
|
CleanGrid();
|
|
CleanGridI();
|
|
|
|
}
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::DBViewChange(TObject *Sender, TTreeNode *Node)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (DBView->Selected != MySQLNode )
|
|
{
|
|
IsDatabase(DBView->Selected->Text);
|
|
|
|
}
|
|
else
|
|
{
|
|
CleanTree();
|
|
}
|
|
}
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::RefreshSClick(TObject *Sender)
|
|
{
|
|
MYSQL_RES *res;
|
|
MYSQL_ROW row;
|
|
unsigned int i;
|
|
AnsiString command;
|
|
|
|
if (IsConnect)
|
|
{
|
|
IsMySQLNode = false;
|
|
CleanTree();
|
|
DBView->Items->Clear();
|
|
|
|
TakeIP();
|
|
|
|
MySQLNode = DBView->Items->Add(NULL, mainroot.UpperCase());
|
|
MySQLNode->ImageIndex = 0;
|
|
|
|
if (!(res=mysql_list_dbs(MySQL,"%"))) { /*do nothing;*/ }
|
|
while ((row=mysql_fetch_row(res)) != 0) {
|
|
mysql_field_seek(res,0);
|
|
|
|
for (i=0 ; i < mysql_num_fields(res); i++)
|
|
{
|
|
MySQLDbs = DBView->Items->AddChild(MySQLNode, row[i]);
|
|
MySQLDbs->ImageIndex = 1;
|
|
MySQLDbs->SelectedIndex = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
mysql_free_result(res);
|
|
|
|
IsMySQLNode = true;
|
|
|
|
MySQLNode->Expanded = true;
|
|
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::CreateDatabaseSClick(TObject *Sender)
|
|
{
|
|
|
|
if (IsConnect)
|
|
{
|
|
dbfrm->Show();
|
|
|
|
}
|
|
else
|
|
ShowMessage("Precisa estar conectado");
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::CleanTree(void)
|
|
{
|
|
StringGrid4->RowCount= 2;
|
|
StringGrid4->Cells[0][1] = "";
|
|
StringGrid4->Cells[1][1] = "";
|
|
StringGrid4->Cells[2][1] = "";
|
|
StringGrid4->Cells[3][1] = "";
|
|
StringGrid4->Cells[4][1] = "";
|
|
StringGrid4->Cells[5][1] = "";
|
|
TableView->Items->Clear();
|
|
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::CleanGrid(void)
|
|
{
|
|
StringGrid4->RowCount= 2;
|
|
StringGrid4->Cells[0][1] = "";
|
|
StringGrid4->Cells[1][1] = "";
|
|
StringGrid4->Cells[2][1] = "";
|
|
StringGrid4->Cells[3][1] = "";
|
|
StringGrid4->Cells[4][1] = "";
|
|
StringGrid4->Cells[5][1] = "";
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::CreatingDB()
|
|
{
|
|
|
|
if (mysql_create_db(MySQL, dbfrm->Edit1->Text.c_str()))
|
|
return true;
|
|
else
|
|
return false;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::OutRefresh(void)
|
|
{
|
|
RefreshSClick(dbfrm->SpeedButton1);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::FlushHosts1Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (mysql_refresh(MySQL,REFRESH_HOSTS))
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::FlushLogs1Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (mysql_refresh(MySQL,REFRESH_LOG))
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|
|
void __fastcall TForm1::FlushTables1Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (mysql_refresh(MySQL,REFRESH_TABLES))
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::IsIndex(String Name)
|
|
{
|
|
MYSQL_RES *res;
|
|
MYSQL_ROW row;
|
|
unsigned int i;
|
|
int k = 0;
|
|
int therow = 1;
|
|
new_line=1;
|
|
AnsiString command;
|
|
AnsiString commandt;
|
|
i = 0;
|
|
CleanGridI();
|
|
command = "use ";
|
|
command+= DBView->Selected->Text.c_str();
|
|
char* las = command.c_str();
|
|
|
|
commandt = "show index from ";
|
|
commandt+= Name.c_str();
|
|
char* les = commandt.c_str();
|
|
|
|
if (mysql_query(MySQL, las ))
|
|
return false;
|
|
|
|
if (mysql_query(MySQL, les ) ||
|
|
!(res=mysql_store_result(MySQL)))
|
|
return false ;
|
|
|
|
StringGrid3->RowCount= 2;
|
|
StringGrid3->Cells[0][0] = "Table";
|
|
StringGrid3->Cells[1][0] = "Non_unique";
|
|
StringGrid3->Cells[2][0] = "Key_name";
|
|
StringGrid3->Cells[3][0] = "Seq_in_index";
|
|
StringGrid3->Cells[4][0] = "Col_name";
|
|
StringGrid3->Cells[5][0] = "Collation";
|
|
StringGrid3->Cells[6][0] = "Card.";
|
|
StringGrid3->Cells[7][0] = "Sub_part";
|
|
StringGrid3->Cells[8][0] = "Packed";
|
|
StringGrid3->Cells[9][0] = "Comment";
|
|
|
|
int thecounter;
|
|
String u = GetNumberServer();
|
|
|
|
if ( u == "3.22")
|
|
{
|
|
StringGrid3->ColCount = 8;
|
|
thecounter = 6;
|
|
}
|
|
else
|
|
thecounter = 8;
|
|
while ((row=mysql_fetch_row(res)) != 0)
|
|
{
|
|
mysql_field_seek(res,0);
|
|
|
|
for (i=0 ; i < mysql_num_fields(res); i++)
|
|
{
|
|
if (k <= thecounter )
|
|
{
|
|
StringGrid3->Cells[k][therow] = row[i];
|
|
k++;
|
|
}
|
|
else
|
|
{
|
|
StringGrid3->Cells[(k)][therow] = row[i];
|
|
k = 0;
|
|
therow++ ;
|
|
StringGrid3->RowCount++;
|
|
}
|
|
}
|
|
|
|
}
|
|
if (i)
|
|
StringGrid3->RowCount--;
|
|
mysql_free_result(res);
|
|
return true;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::CleanGridI(void)
|
|
{
|
|
StringGrid3->RowCount= 2;
|
|
StringGrid3->Cells[0][1] = "";
|
|
StringGrid3->Cells[1][1] = "";
|
|
StringGrid3->Cells[2][1] = "";
|
|
StringGrid3->Cells[3][1] = "";
|
|
StringGrid3->Cells[4][1] = "";
|
|
StringGrid3->Cells[5][1] = "";
|
|
StringGrid3->Cells[6][1] = "";
|
|
StringGrid3->Cells[7][1] = "";
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::CreatingTable(String TheTable)
|
|
{
|
|
|
|
if (!mysql_query(MySQL, TheTable.c_str()))
|
|
return true;
|
|
else
|
|
return false;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::GetExtendedStatus()
|
|
{
|
|
if (!ya && !preport)
|
|
return true;
|
|
|
|
MYSQL_RES *res;
|
|
MYSQL_ROW row;
|
|
unsigned int i;
|
|
int k = 1;
|
|
new_line=1;
|
|
bool left = true;
|
|
bool open_tables = false;
|
|
bool open_files = false;
|
|
bool uptime = false;
|
|
bool running_threads = false;
|
|
bool open_streams = false;
|
|
bool slow_queries = false;
|
|
bool opened_tables = false;
|
|
bool questions = false;
|
|
|
|
AnsiString report;
|
|
if (yy)
|
|
StringGrid5->RowCount = 2;
|
|
|
|
if (mysql_query(MySQL,"show status") ||
|
|
!(res=mysql_store_result(MySQL)))
|
|
{
|
|
return false;
|
|
}
|
|
|
|
while ((row=mysql_fetch_row(res)) != 0)
|
|
{
|
|
mysql_field_seek(res,0);
|
|
|
|
StringGrid5->Cells[0][0] = "Variable Name";
|
|
StringGrid5->Cells[1][0] = "Value";
|
|
|
|
|
|
for (i=0 ; i < mysql_num_fields(res); i++)
|
|
{
|
|
|
|
if (left)
|
|
{
|
|
if (preport)
|
|
report = GetString(row[i]);
|
|
if ( (String) row[i] == "Open_tables")
|
|
open_tables = true;
|
|
else
|
|
open_tables = false;
|
|
if ( (String) row[i] == "Open_files")
|
|
open_files = true;
|
|
else
|
|
open_files = false;
|
|
if ((String) row[i] == "Uptime")
|
|
uptime = true;
|
|
else
|
|
uptime = false;
|
|
|
|
if ( (String) row[i] == "Opened_tables")
|
|
opened_tables = true;
|
|
else
|
|
opened_tables = false;
|
|
|
|
if ( (String) row[i] == "Threads_running" || (String) row[i] == "Running_threads")
|
|
running_threads = true;
|
|
else
|
|
running_threads = false;
|
|
|
|
if ( (String) row[i] == "Open_streams")
|
|
open_streams = true;
|
|
else
|
|
open_streams = false;
|
|
|
|
if ( (String) row[i] == "Slow_queries")
|
|
slow_queries = true;
|
|
else
|
|
slow_queries = false;
|
|
|
|
if ( (String) row[i] == "Questions")
|
|
questions = true;
|
|
else
|
|
questions = false;
|
|
|
|
if (yy)
|
|
StringGrid5->Cells[0][k++] = row[i];
|
|
|
|
left = false;
|
|
}
|
|
else
|
|
{
|
|
if (preport)
|
|
Memo5->Lines->Add(report + row[i]);
|
|
if (open_tables)
|
|
st22->Text = row[i];
|
|
if (open_files)
|
|
st23->Text = row[i];
|
|
if (uptime)
|
|
nice_time(row[i]);
|
|
if (running_threads)
|
|
st27->Text = row[i];
|
|
if (open_streams)
|
|
st24->Text = row[i];
|
|
if (slow_queries)
|
|
st28->Text = row[i];
|
|
if (opened_tables)
|
|
st25->Text = row[i];
|
|
if (questions){
|
|
q++;
|
|
st26->Text = StrToInt64(row[i]) - q; }
|
|
|
|
if (yy){
|
|
StringGrid5->RowCount++;
|
|
StringGrid5->Cells[1][--k] = row[i];
|
|
k++; }
|
|
|
|
left = true;
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
if (rinit)
|
|
StringGrid5->RowCount--;
|
|
mysql_free_result(res);
|
|
yy = false;
|
|
return true;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::SpeedButton13Click(TObject *Sender)
|
|
{
|
|
yy = true;
|
|
// rinit = true;
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
String __fastcall TForm1::GetNumberServer()
|
|
{
|
|
String TheVersion;
|
|
|
|
TheVersion = mysql_get_server_info(MySQL) ;
|
|
TheVersion.SetLength(4);
|
|
return TheVersion;
|
|
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
void __fastcall TForm1::KillProcess1Click(TObject *Sender)
|
|
{
|
|
|
|
if (IsConnect)
|
|
KillPID();
|
|
else
|
|
Application->MessageBox("The Server must be connected", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
bool __fastcall TForm1::KillPID()
|
|
{
|
|
String s = "Are you sure to kill the process PID no. ";
|
|
s+= StringGrid2->Cells[0][StringGrid2->Row];
|
|
s+= " of the USER ";
|
|
s+= StringGrid2->Cells[1][StringGrid2->Row];
|
|
unsigned long xx = mysql_thread_id(MySQL);
|
|
unsigned long yy = StrToInt(StringGrid2->Cells[0][StringGrid2->Row]);
|
|
if ( xx != yy)
|
|
{
|
|
if(Application->MessageBox(s.c_str(), "WinMySQLadmin 1.0", MB_YESNOCANCEL | MB_ICONQUESTION ) == IDYES)
|
|
{
|
|
if (!mysql_kill(MySQL,yy))
|
|
{
|
|
GetProcess();
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
Application->MessageBox("From here you can't kill the PID of this tool", "WinMySQLadmin 1.0", MB_OK | MB_ICONEXCLAMATION);
|
|
return true;
|
|
}
|
|
return true;
|
|
}
|
|
void __fastcall TForm1::FlushThreads1Click(TObject *Sender)
|
|
{
|
|
if (IsConnect)
|
|
{
|
|
if (mysql_refresh(MySQL,REFRESH_THREADS))
|
|
StatusLine->SimpleText = "";
|
|
}
|
|
}
|
|
//---------------------------------------------------------------------------
|
|
|