I\'m currently experimenting with OData endpoints in ASP.NET MVC 4 Web API. I like the concept and try to come up with efficient ways to use it in our project. One question I h
I came up against the same problem, and ended up writing a custom IHttpControllerSelector
instead of an IODataRoutingConvention
. IODataRoutingConvention
looks like a good option if your generic controller doesn't require generics :) . But since IODataRoutingConvention.SelectController()
only returns a string, I don't see how it will work for instantiating a controller with generic type parameters.
I decided this problem needs a good, general-purpose, open-source solution - so I created one: https://github.com/EntityRepository/ODataServer . It's prerelease now, but I'm currently doing a lot of work on it. I think there's more to it than just choosing the right controller, there are general patterns to define for shared controllers, and by default Web API OData expects strongly typed and strongly named navigation properties which makes it challenging to create a re-usable implementation.