I have function in my adapter "findQuery" the function need to GET data from the server and return it.
the function:
findQuery: function(store, type, query) {
var userId = query['user_id'];
delete query['user_id'];
if (this.sortQueryParams) {
query = this.sortQueryParams(query);
}
var adapter = this;
// Create nested url
//return this.ajax(this.urlPrefix(this.pathForType(type.typeKey), this.buildURL(type, userId)), 'GET', { data: query });
// We would like to relate the rows to the connected user
return new Ember.RSVP.Promise(function(resolve, reject) {
adapter.ajax(adapter.buildURL(type.typeKey, null, userId), 'GET', { data: query }).then(function(devices) {
store.find('user', userId).then(function(user) {
devices.setEach('user_id', user);
resolve(devices); // devices is set exactly as i wanted!
}, function(failed) {
reject(failed);
});
}, function(error) {
reject(error);
});
});
}
So when I debug the function Ii see that the function get into the resolve with the correct data (the API returned all the requested data as Array of objects). And then I get log Error:
Error: Assertion Failed: The response from a findQuery must be an Array, not undefined
UPDATE
The issue has been solved but I still don't understand why it occurs.
what happen?
I set in store-injector file
inflector.irregular('general_device', 'devices');
That resolve for me the api endpoints that look like that:
While in some way it has some conflict, what I tried is to resolve an url with the above function that look like that:
It solved but I can't find references why it happened, it make a sense but still I hope that someone could explain the reason for it to happen.
You need to return a PromiseArray.
See the documentation on an example of how to use it.
In you example, it would be changed to: