From fe930a9b78d561b0afedc98b4a28cbdfc777e70a Mon Sep 17 00:00:00 2001 From: Carlos Afonso Date: Tue, 12 Jun 2018 09:13:32 +0200 Subject: [PATCH] Suggest cause of MalformedQueryExceptions for possible Amazon Neptune users (#41) --- scripts/graphioGremlin.js | 37 +++++++++++++++++++++++++++---------- 1 file changed, 27 insertions(+), 10 deletions(-) diff --git a/scripts/graphioGremlin.js b/scripts/graphioGremlin.js index fa04850..2410c06 100644 --- a/scripts/graphioGremlin.js +++ b/scripts/graphioGremlin.js @@ -235,19 +235,36 @@ var graphioGremlin = (function(){ }, error: function(result, status, error){ console.log("Connection failed. "+status); + + // This will hold all error messages, to be printed in the + // output area. + let msgs = []; + if (query_type == 'editGraph'){ - $('#outputArea').html("

Problem accessing the database using REST at "+server_url+"

"+ - "

Message: "+status+ ", "+error+"

"+ - "

Possible cause: creating a edge with bad node ids "+ - "(linking nodes not existing in the DB).

"); - $('#messageArea').html(''); + msgs.push('Problem accessing the database using REST at ' + server_url); + msgs.push('Message: ' + status + ', ' + error); + msgs.push('Possible cause: creating an edge with bad node ids ' + + '(linking nodes not existing in the DB).'); } else { - $('#outputArea').html("

Can't access database using REST at "+server_url+"

"+ - "

Message: "+status+ ", "+error+"

"+ - "

Check the server configuration "+ - "or try increasing the REST_TIMEOUT value in the config file.

"); - $('#messageArea').html(''); + msgs.push('Can\'t access database using REST at ' + server_url); + msgs.push('Message: ' + status + ', ' + error); + msgs.push('Check the server configuration ' + + 'or try increasing the REST_TIMEOUT value in the config file.'); } + + // If a MalformedQueryException is received, user might be + // trying to reach an Amazon Neptune DB. Point them to the + // config file as a probable cause. + if (result.status === 400 + && SINGLE_COMMANDS_AND_NO_VARS === false + && result.hasOwnProperty('responseJSON') + && result.responseJSON.code === 'MalformedQueryException') { + msgs.push('If connecting to an Amazon Neptune databse, ensure that ' + + 'SINGLE_COMMANDS_AND_NO_VARS is set to true in the config file.'); + } + + $('#outputArea').html(msgs.map(function (i) {return '

' + i + '

'}).join('')); + $('#messageArea').html(''); } }); }