diff --git a/src/zmapServer/zmapServer.c b/src/zmapServer/zmapServer.c index 3cdef3c9e45c15bfc54e10cace01275200b24339..e65f19b5a7e34d52ac11d1aec0c0883b799d9da9 100755 --- a/src/zmapServer/zmapServer.c +++ b/src/zmapServer/zmapServer.c @@ -26,43 +26,99 @@ * Description: * Exported functions: See zmapServer.h * HISTORY: - * Last edited: Sep 5 16:20 2003 (edgrif) + * Last edited: Mar 22 10:42 2004 (edgrif) * Created: Wed Aug 6 15:46:38 2003 (edgrif) - * CVS info: $Id: zmapServer.c,v 1.1 2003-11-13 15:01:09 edgrif Exp $ + * CVS info: $Id: zmapServer.c,v 1.2 2004-03-22 13:22:25 edgrif Exp $ *------------------------------------------------------------------- */ -#include <AceConn.h> +#include <strings.h> +#include <ZMap/zmapUtils.h> #include <zmapServer_P.h> +/* We need matching serverInit and serverCleanup functions that are only called once + * for each server type, libcurl needs this to avoid memory leaks but maybe this is not + * such an issue for us as its once per program run...... */ -gboolean zMapServerCreateConnection(ZMapServer *server_out, char *host, int port, + +/* This routine must be called before any other server routine and must only be called once, + * it is the callers responsibility to make sure this is true.... + * NOTE the result is always TRUE at the moment because if we fail on any of these we crash... */ +gboolean zMapServerGlobalInit(char *protocol, void **server_global_data_out) +{ + gboolean result = TRUE ; + ZMapServerFuncs serverfuncs ; + + serverfuncs = g_new(ZMapServerFuncsStruct, sizeof(ZMapServerFuncsStruct)) ; /* n.b. crashes on failure. */ + + /* Set up the server according to the protocol, this is all a bit hard coded but it + * will do for now.... */ + /* Probably I should do this with a table of protocol and function stuff...perhaps + * even using dynamically constructed function names.... */ + if (strcasecmp(protocol, "acedb") == 0) + { + acedbGetServerFuncs(serverfuncs) ; /* Must not fail..check with assert ? */ + } + else if (strcasecmp(protocol, "das") == 0) + { + dasGetServerFuncs(serverfuncs) ; /* Must not fail..check with assert ? */ + } + else + { + /* Fatal error..... */ + /* THIS "Internal Error" SHOULD BE IN A MACRO SO WE GET CONSISTENT MESSAGES..... */ + ZMAPFATALERR("Internal Error: unsupported server protocol: %s", protocol) ; + + } + + + /* Call the global init function. */ + if (result) + { + result = (serverfuncs->global_init)() ; + } + + if (result) + *server_global_data_out = (void *)serverfuncs ; + + return result ; +} + + + +gboolean zMapServerCreateConnection(ZMapServer *server_out, void *global_data, + char *host, int port, char *protocol, char *userid, char *passwd) { - gboolean result = FALSE ; + gboolean result = TRUE ; ZMapServer server ; - AceConnection connection = NULL ; - AceConnStatus status ; + ZMapServerFuncs serverfuncs = (ZMapServerFuncs)global_data ; + - /* slightly odd, always return a struct to provide error information. */ server = g_new(ZMapServerStruct, sizeof(ZMapServerStruct)) ; /* n.b. crashes on failure. */ *server_out = server ; - if ((status = AceConnCreate(&connection, host, port, userid, passwd, 20)) == ACECONN_OK) - { - /* Don't know if we really need to keep hold of these... */ - server->host = g_strdup(host) ; - server->port = port ; - - server->connection = connection ; + /* set function table. */ + server->funcs = serverfuncs ; - server->last_error_msg = NULL ; - - result = TRUE ; + if (result) + { + if ((server->funcs->create)(&(server->server_conn), host, port, userid, passwd, 20)) + { + server->host = g_strdup(host) ; + server->port = port ; + server->protocol = g_strdup(protocol) ; + server->last_error_msg = NULL ; + + result = TRUE ; + } + else + { + server->last_error_msg = (server->funcs->errmsg)(server->server_conn) ; + result = FALSE ; + } } - else - server->last_error_msg = AceConnGetErrorMsg(connection, status) ; return result ; } @@ -71,45 +127,39 @@ gboolean zMapServerCreateConnection(ZMapServer *server_out, char *host, int port gboolean zMapServerOpenConnection(ZMapServer server) { gboolean result = FALSE ; - AceConnStatus status ; - if ((status = AceConnConnect(server->connection)) == ACECONN_OK) + if ((server->funcs->open)(server->server_conn)) result = TRUE ; else - server->last_error_msg = AceConnGetErrorMsg(server->connection, status) ; + server->last_error_msg = (server->funcs->errmsg)(server->server_conn) ; return result ; } -gboolean zMapServerRequest(ZMapServer server, char *request, char **reply) +/* NEED TO SORT OUT WHETHER WE RETURN C STRINGS OR NOT.... */ +gboolean zMapServerRequest(ZMapServer server, char *request, char **reply, int *reply_len) { gboolean result = FALSE ; - int reply_len = 0 ; - AceConnStatus status ; - if ((status = AceConnRequest(server->connection, request, (void **)reply, &reply_len)) == ACECONN_OK) + if ((server->funcs->request)(server->server_conn, request, (void **)reply, reply_len)) result = TRUE ; else - server->last_error_msg = AceConnGetErrorMsg(server->connection, status) ; + server->last_error_msg = (server->funcs->errmsg)(server->server_conn) ; return result ; } gboolean zMapServerCloseConnection(ZMapServer server) { - gboolean result = TRUE ; - AceConnStatus status ; + gboolean result = FALSE ; - if ((status = AceConnConnectionOpen(server->connection)) == ACECONN_OK) + if ((server->funcs->close)(server->server_conn)) { - if ((status = AceConnDisconnect(server->connection)) != ACECONN_OK) - result = FALSE ; - else - server->last_error_msg = AceConnGetErrorMsg(server->connection, status) ; + result = TRUE ; } else - server->last_error_msg = AceConnGetErrorMsg(server->connection, status) ; + server->last_error_msg = (server->funcs->errmsg)(server->server_conn) ; return result ; } @@ -118,8 +168,9 @@ gboolean zMapServerFreeConnection(ZMapServer server) { gboolean result = TRUE ; - AceConnDestroy(server->connection) ; /* Does not fail. */ + (server->funcs->destroy)(server->server_conn) ; g_free(server->host) ; + g_free(server->protocol) ; g_free(server) ; return result ;