8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-24 02:43:03 +01:00

Allowed Services API for win32 CS (gbak/gfix only). gstat/gsec are not supported yet.

This commit is contained in:
dimitr 2003-03-29 15:49:38 +00:00
parent e1a3921e00
commit c18c6f17bd

View File

@ -473,7 +473,7 @@ SVC SVC_attach(USHORT service_length,
************************************** **************************************
* *
* Functional description * Functional description
* Connect to an Interbase service. * Connect to a Firebird service.
* *
**************************************/ **************************************/
@ -1342,13 +1342,10 @@ void SVC_putc(SVC service, UCHAR ch)
if (item == isc_info_svc_line) if (item == isc_info_svc_line)
get_flags = GET_LINE; get_flags = GET_LINE;
else if (item == isc_info_svc_to_eof)
get_flags = GET_EOF;
else else
{ get_flags = GET_BINARY;
if (item == isc_info_svc_to_eof)
get_flags = GET_EOF;
else
get_flags = GET_BINARY;
}
service_get(service, info + 3, end - (info + 4), get_flags, service_get(service, info + 3, end - (info + 4), get_flags,
timeout, &length); timeout, &length);
@ -1905,7 +1902,7 @@ void *SVC_start(SVC service, USHORT spb_length, SCHAR * spb)
************************************** **************************************
* *
* Functional description * Functional description
* Start an InterBase service * Start a Firebird service
* *
**************************************/ **************************************/
TDBB tdbb; TDBB tdbb;
@ -1984,7 +1981,8 @@ void *SVC_start(SVC service, USHORT spb_length, SCHAR * spb)
*spb == isc_action_svc_delete_user || *spb == isc_action_svc_delete_user ||
*spb == isc_action_svc_modify_user || *spb == isc_action_svc_modify_user ||
*spb == isc_action_svc_display_user || *spb == isc_action_svc_display_user ||
*spb == isc_action_svc_db_stats || *spb == isc_action_svc_properties) { *spb == isc_action_svc_db_stats ||
*spb == isc_action_svc_properties) {
/* the user issued a username when connecting to the service so /* the user issued a username when connecting to the service so
* add the length of the username and switch to new_spb_length * add the length of the username and switch to new_spb_length
*/ */
@ -2002,9 +2000,10 @@ void *SVC_start(SVC service, USHORT spb_length, SCHAR * spb)
sizeof(PASSWORD_SWITCH)); sizeof(PASSWORD_SWITCH));
/* If svc_switches is not used -- call a command-line parsing utility */ /* If svc_switches is not used -- call a command-line parsing utility */
if (!service->svc_switches) if (!service->svc_switches) {
conv_switches(spb_length, opt_switch_len, spb, conv_switches(spb_length, opt_switch_len, spb,
&service->svc_switches); &service->svc_switches);
}
else { else {
/* Command line options (isc_spb_options) is used. /* Command line options (isc_spb_options) is used.
* Currently the only case in which it might happen is -- gbak utility * Currently the only case in which it might happen is -- gbak utility
@ -2051,13 +2050,15 @@ void *SVC_start(SVC service, USHORT spb_length, SCHAR * spb)
} }
} }
} }
else
/* If svc_switches is not used -- call a command-line parsing utility */
if (!service->svc_switches)
conv_switches(spb_length, opt_switch_len, spb,
&service->svc_switches);
else { else {
assert(service->svc_switches == NULL); /* If svc_switches is not used -- call a command-line parsing utility */
if (!service->svc_switches) {
conv_switches(spb_length, opt_switch_len, spb,
&service->svc_switches);
}
else {
assert(service->svc_switches == NULL);
}
} }
/* All services except for get_ib_log require switches */ /* All services except for get_ib_log require switches */
if (service->svc_switches == NULL && *spb != isc_action_svc_get_ib_log) if (service->svc_switches == NULL && *spb != isc_action_svc_get_ib_log)
@ -2243,7 +2244,7 @@ void SVC_read_ib_log(SVC service)
************************************** **************************************
* *
* Functional description * Functional description
* Service function which reads the InterBase * Service function which reads the Firebird
* log file into the service buffers. * log file into the service buffers.
* *
**************************************/ **************************************/
@ -2608,6 +2609,11 @@ static void service_fork(TEXT * service_path, SVC service)
q++; q++;
} }
for (q = argv_data; *q; q++) {
if (*q == SVC_TRMNTR)
*q = ' ';
}
THREAD_EXIT; THREAD_EXIT;
start_crud.cb = sizeof(STARTUPINFO); start_crud.cb = sizeof(STARTUPINFO);
@ -2616,17 +2622,15 @@ static void service_fork(TEXT * service_path, SVC service)
start_crud.cbReserved2 = 0; start_crud.cbReserved2 = 0;
start_crud.lpDesktop = NULL; start_crud.lpDesktop = NULL;
start_crud.lpTitle = NULL; start_crud.lpTitle = NULL;
start_crud.dwFlags = STARTF_USESTDHANDLES; start_crud.dwFlags = STARTF_USESHOWWINDOW;
start_crud.hStdInput = my_output; start_crud.wShowWindow = SW_HIDE;
start_crud.hStdOutput = my_input;
start_crud.hStdError = my_input;
if (!(ret = CreateProcess(NULL, if (!(ret = CreateProcess(NULL,
argv_data, argv_data,
NULL, NULL,
NULL, NULL,
TRUE, TRUE,
NORMAL_PRIORITY_CLASS | DETACHED_PROCESS, NORMAL_PRIORITY_CLASS,
NULL, NULL,
NULL, NULL,
&start_crud, &pi))) status = GetLastError(); &start_crud, &pi))) status = GetLastError();
@ -2657,11 +2661,12 @@ static void service_fork(TEXT * service_path, SVC service)
} }
static void service_get( static void service_get(SVC service,
SVC service,
SCHAR * buffer, SCHAR * buffer,
USHORT length, USHORT length,
USHORT flags, USHORT timeout, USHORT * return_length) USHORT flags,
USHORT timeout,
USHORT * return_length)
{ {
/************************************** /**************************************
* *
@ -2793,9 +2798,7 @@ static void service_put(SVC service, SCHAR * buffer, USHORT length)
} }
static USHORT service_read( static USHORT service_read(SVC service, SCHAR * buffer, USHORT length, USHORT flags)
SVC service,
SCHAR * buffer, USHORT length, USHORT flags)
{ {
/************************************** /**************************************
* *
@ -2810,10 +2813,8 @@ static USHORT service_read(
* special character. * special character.
* *
**************************************/ **************************************/
SLONG len, n = 0L; SLONG len, n = 0;
SCHAR *buf; SCHAR *buf = buffer;
buf = buffer;
while (length) { while (length) {
n = 0; n = 0;
@ -2835,6 +2836,9 @@ static USHORT service_read(
isc_io_read_err, TRUE); isc_io_read_err, TRUE);
} }
if ((flags & GET_LINE) && buf[-1] == '\n')
buf[-1] = ' ';
return buf - buffer; return buf - buffer;
} }
#endif /* ifndef SUPERSERVER */ #endif /* ifndef SUPERSERVER */
@ -3281,7 +3285,7 @@ static void service_fork(TEXT * service_path, SVC service)
strcat (buf, *s); strcat (buf, *s);
s++; s++;
} }
gds__log (buf); gds__log(buf);
} }
#endif #endif
execvp(argv[0], argv); execvp(argv[0], argv);
@ -3611,7 +3615,6 @@ static USHORT process_switches(
TEXT *p, *sw; TEXT *p, *sw;
ISC_USHORT svc_action; ISC_USHORT svc_action;
BOOLEAN found = FALSE; BOOLEAN found = FALSE;
//BOOLEAN lic_key = FALSE, lic_id = FALSE;
if (spb_length == 0) if (spb_length == 0)
return 0; return 0;
@ -3909,22 +3912,33 @@ static void get_action_svc_string(
* when creating the argc / argv paramters for the service. * when creating the argc / argv paramters for the service.
* *
**************************************/ **************************************/
ISC_USHORT l; ISC_USHORT l, l2;
l = l = gds__vax_integer(reinterpret_cast < UCHAR * >(*spb),
gds__vax_integer(reinterpret_cast < UCHAR * >(*spb),
sizeof(ISC_USHORT)); sizeof(ISC_USHORT));
const char* local_server = "localhost:";
#if defined(WIN_NT) && !defined(SUPERSERVER)
// dimitr: temporary hack to make Services API available
// for the engine without support of local protocol.
// Once XNET is implemented in win32 CS, remove this ugly code.
TEXT * spb_item = *spb - 1;
l2 = (*spb_item == isc_spb_dbname) ? strlen(local_server) : 0;
#else
l2 = 0;
#endif
/* Do not go beyond the bounds of the spb buffer */ /* Do not go beyond the bounds of the spb buffer */
if (l > *len) if (l > *len)
ERR_post(isc_bad_spb_form, 0); ERR_post(isc_bad_spb_form, 0);
*spb += sizeof(ISC_USHORT); *spb += sizeof(ISC_USHORT);
if (*cmd) if (*cmd)
{ {
**cmd = SVC_TRMNTR; **cmd = SVC_TRMNTR;
*cmd += 1; *cmd += 1;
MOVE_FASTER(local_server, *cmd, l2);
*cmd += l2;
MOVE_FASTER(*spb, *cmd, l); MOVE_FASTER(*spb, *cmd, l);
*cmd += l; *cmd += l;
**cmd = SVC_TRMNTR; **cmd = SVC_TRMNTR;
@ -3933,7 +3947,7 @@ static void get_action_svc_string(
*cmd += 1; *cmd += 1;
} }
*spb += l; *spb += l;
*total += l + 1 + 2; /* Two SVC_TRMNTR for strings */ *total += l + l2 + 1 + 2; /* Two SVC_TRMNTR for strings */
*len -= sizeof(ISC_USHORT) + l; *len -= sizeof(ISC_USHORT) + l;
} }