Merge pull request #98 from strongloop/feature/fix-issue-97

Fix the method for belongsTo with correct receiver
This commit is contained in:
Raymond Feng 2014-04-04 08:27:55 -07:00
commit a1f8919e13
2 changed files with 7 additions and 5 deletions

View File

@ -119,9 +119,8 @@ Inclusion.include = function (objects, include, cb) {
}
}
var inst = (obj instanceof self) ? obj : new self(obj);
var relationMethod = inst[relationName];
// FIXME: [rfeng] How do we pass in the refresh flag?
relationMethod(function (err, result) {
// Calling the relation method on the instance
inst[relationName](function (err, result) {
if (err) {
return callback(err);
} else {

View File

@ -340,10 +340,13 @@ Relation.belongsTo = function (anotherClass, params) {
// Define a property for the scope so that we have 'this' for the scoped methods
Object.defineProperty(this.prototype, methodName, {
enumerable: false,
enumerable: true,
configurable: true,
get: function () {
var fn = relationMethod.bind(this);
var fn = function() {
// Call the relation method on the declaring model instance
return relationMethod.apply(this, arguments);
}
// Set the remoting metadata so that it can be accessed as /api/<model>/<id>/<belongsToRelationName>
// For example, /api/orders/1/customer
fn.shared = true;