Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Restangular: getList with object containing embedded array

In my AngularJS project I'm trying to use the Restangular getList method but it's returning an error because the API response is not directly an array but an object containing an array.

{
  "body": [
    // array elements here
  ],
  "paging": null,
  "error": null
}

The Restangular error message is:

Error: Response for getList SHOULD be an array and not an object or something else

Is it possible to tell Restangular that the array it's looking for is inside the body property?

like image 331
Guilhem Soulas Avatar asked Feb 25 '14 11:02

Guilhem Soulas


3 Answers

Yes, see the Restangular documentation. You can configure Restangular like so:

rc.setResponseExtractor(function(response, operation) {     if (operation === 'getList') {         var newResponse = response.body;         newResponse.paging = response.paging;         newResponse.error = response.error;         return newResponse;     }     return response; }); 

Edit: It seems Restangular's API is now changed, for the better, and that the current method to use is addResponseInterceptor. Some adjustments might be needed to the function passed.

like image 181
Mikke Avatar answered Sep 30 '22 07:09

Mikke


I think you should use a the customGET from the Custom Methods

Restangular.all("url").customGET(""); // GET /url and handle the response as an Object

like image 29
Thram Avatar answered Sep 30 '22 05:09

Thram


as Collin Allen suggested you can use addResponseInterceptor like this:

    app.config(function(RestangularProvider) {

        // add a response intereceptor
        RestangularProvider.addResponseInterceptor(function(data, operation, what, url, response, deferred) {
          var extractedData;
          // .. to look for getList operations
          if (operation === "getList") {
            // .. and handle the data and meta data
            extractedData = data.body;
            extractedData.error = data.error;
            extractedData.paging = data.paging;
          } else {
            extractedData = data.data;
          }
          return extractedData;
        });

});
like image 37
Ouadie Avatar answered Sep 30 '22 06:09

Ouadie