I have an ASP.NET Web API app using Entity Framework and Odata.
I would like to modify the results of a query when using a GET... currently, within the controller, you effectively just pass the EntityFramework data entities back to the Odata handlers...
[EnableQuery]
public IQueryable<myEntity> GetLineItem()
{
return db.myEntities;
}
It's simple to prepend whatever query Odata passes into this by simply returning a subset
return db.myEntity.Where(myEntity => myEntity.Name == "Bob")
Odata will add whatever is in the $filter querystring parameter to the expression passed in here and you get the subset of these results.
However, I would like to iterate over the results once the query executes and the SQL results are parsed into entity objects.
I have tried creating a wrapper that implements the IQueryable interface and hooking into the GetEnumerator methods and the same for the IProvider and hooking into the execute method. Odata doesn't seem to be using either one of these.
Is there a way to do this?