From 6ce3cf03857caa62f7c51af22c62800a7bef03c0 Mon Sep 17 00:00:00 2001 From: scottmk Date: Wed, 26 May 2010 13:27:29 +0000 Subject: [PATCH] Bug fixes in verifyObjectPCRUD(): 1. Don't throw an exception just because a foreign key is null. 2. When looking for local or foreign contexts, always do a lookup of the current row, even if you already have an image of that row in hand. The image you have may not include the foreign key(s) you need. The latter fix is simple but inefficient. It should be possible to avoid the extra lookup most of the time, and maybe all of the time, for the search, retrieve, and id_list methods. However that will involve additional complications, not yet implemented. Let's make it correct first, and worry about efficiency later. M Open-ILS/src/c-apps/oils_sql.c git-svn-id: svn://svn.open-ils.org/ILS/trunk@16504 dcc99617-32d9-48b4-a31d-7c20da2025e4 --- Open-ILS/src/c-apps/oils_sql.c | 36 ++++++++++++++++++++++++------------ 1 file changed, 24 insertions(+), 12 deletions(-) diff --git a/Open-ILS/src/c-apps/oils_sql.c b/Open-ILS/src/c-apps/oils_sql.c index f87483f9eb..573fc611d2 100644 --- a/Open-ILS/src/c-apps/oils_sql.c +++ b/Open-ILS/src/c-apps/oils_sql.c @@ -139,7 +139,7 @@ static char* modulename = NULL; /** @brief Connect to the database. @return A database connection if successful, or NULL if not. - */ +*/ dbi_conn oilsConnectDB( const char* mod_name ) { osrfLogDebug( OSRF_LOG_MARK, "Attempting to initialize libdbi..." ); @@ -1267,7 +1267,14 @@ static int verifyObjectPCRUD ( osrfMethodContext* ctx, const jsonObject* obj ) osrfHash* class = osrfHashGet( method_metadata, "class" ); const char* method_type = osrfHashGet( method_metadata, "methodtype" ); - int fetch = 0; + // Set fetch to 1 in all cases, meaning that for local or foreign contexts we will + // always do another lookup of the current row, even if we already have a row image, + // because the row image in hand may not include the foreign key(s) that we need. + + // This is a quick fix with a bludgeon. There are ways to avoid the extra lookup, + // but they aren't implemented yet. + //int fetch = 0; + int fetch = 1; if( *method_type == 's' || *method_type == 'i' ) { method_type = "retrieve"; // search and id_list are equivalent to retrieve for this } else if( *method_type == 'u' || *method_type == 'd' ) { @@ -1409,20 +1416,23 @@ static int verifyObjectPCRUD ( osrfMethodContext* ctx, const jsonObject* obj ) if( local_context && local_context->size > 0 ) { // The IDL provides a list of column names for the foreign keys denoting - // local context. Look up the value of each one, and add it to the - // list of org units. + // local context. Look up the value of each one, and if it isn't null, + // add it to the list of org units. osrfLogDebug( OSRF_LOG_MARK, "%d class-local context field(s) specified", local_context->size ); int i = 0; const char* lcontext = NULL; while ( (lcontext = osrfStringArrayGetString(local_context, i++)) ) { - osrfStringArrayAdd( context_org_array, oilsFMGetStringConst( param, lcontext )); - osrfLogDebug( - OSRF_LOG_MARK, - "adding class-local field %s (value: %s) to the context org list", - lcontext, - osrfStringArrayGetString( context_org_array, context_org_array->size - 1 ) - ); + const char* fkey_value = oilsFMGetStringConst( param, lcontext ); + if( fkey_value ) { // if not null + osrfStringArrayAdd( context_org_array, fkey_value ); + osrfLogDebug( + OSRF_LOG_MARK, + "adding class-local field %s (value: %s) to the context org list", + lcontext, + osrfStringArrayGetString( context_org_array, context_org_array->size - 1 ) + ); + } } } @@ -1455,6 +1465,8 @@ static int verifyObjectPCRUD ( osrfMethodContext* ctx, const jsonObject* obj ) // Get the value of the foreign key pointing to the foreign table char* foreign_pkey_value = oilsFMGetString( param, osrfHashGet( fcontext, "fkey" )); + if( !foreign_pkey_value ) + continue; // Foreign key value is null; skip it // Look up the row to which the foreign key points jsonObject* _tmp_params = single_hash( foreign_pkey, foreign_pkey_value ); @@ -1516,7 +1528,7 @@ static int verifyObjectPCRUD ( osrfMethodContext* ctx, const jsonObject* obj ) "%s: no object found with primary key %s of %s", modulename, foreign_pkey, - foreign_pkey_value + foreign_pkey_value ? foreign_pkey_value : "(null)" ); char* m = buffer_release( msg ); -- 2.11.0