Reputation: 101
{
"error": {
"statusCode": 500,
"name": "TypeError",
"message": "Cannot read property 'connector' of undefined",
"stack": "TypeError: Cannot read property 'connector' of undefined\n at Function.Projects.getProjectData (F:\\SanWork\\AngularWorkSpace\\jobMngt\\common\\models\\projects.js:7:44)\n at SharedMethod.invoke (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\strong-remoting\\lib\\shared-method.js:263:25)\n at HttpContext.invoke (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\strong-remoting\\lib\\http-context.js:389:12)\n at phaseInvoke (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\strong-remoting\\lib\\remote-objects.js:654:9)\n at runHandler (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\lib\\phase.js:135:5)\n at iterate (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\node_modules\\async\\lib\\async.js:146:13)\n at Object.async.eachSeries (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\node_modules\\async\\lib\\async.js:162:9)\n at runHandlers (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\lib\\phase.js:144:13)\n at iterate (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\node_modules\\async\\lib\\async.js:146:13)\n at F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\node_modules\\async\\lib\\async.js:157:25\n at F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\node_modules\\async\\lib\\async.js:154:25\n at execStack (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\strong-remoting\\lib\\remote-objects.js:493:7)\n at RemoteObjects.execHooks (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\strong-remoting\\lib\\remote-objects.js:497:10)\n at phaseBeforeInvoke (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\strong-remoting\\lib\\remote-objects.js:650:10)\n at runHandler (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\lib\\phase.js:135:5)\n at iterate (F:\\SanWork\\AngularWorkSpace\\jobMngt\\node_modules\\loopback-phase\\node_modules\\async\\lib\\async.js:146:13)"
}
}
Getting this error when using this code, I would like to know what is causing the error and any possible fixes.
model code:
'use strict';
module.exports = function(Projects) {
Projects.getProjectData = function(cb) {
var sql = 'select * from projects';
// call sql query from postreSQL
Projects.app.datasources.postgres.connector.query(sql, function(err, result) {
if (err) {
console.log('Error retrieving projects result ...');
console.log(err);
return cb(err);
}
cb(err, result[0].jsondata);
});
}
Projects.remoteMethod(
'getProjectData', {
returns: [{
type: 'string',
required: true,
root: true
}],
http: {
verb: 'get'
}
}
);
};
I already installed loopback-connector-postgresql & generated the models but when I tried for writing custom api getting error.
Upvotes: 0
Views: 1273
Reputation: 830
before the module.exports
declare
var app = require('../../server/server.js');
this is from the assumption that you are in the model directory in common folder.
then instead of using Projects.app.datasource
use app.datasource
Upvotes: 1