Search code examples
asp.net-web-apiodata

OData V4 + WebAPI Filter by Int Value of Enum?


OData V4 has enum support but it appears you have to search by the namespace only. How does one now search by the value instead of the text representation?

In V3 of odata you could query for $filter=Status eq 35, where 35 is Complete in the enum. This method would work, even if that field was an enum field in the data model.

Now this method fails in V4, instead requiring the namespace with text representation of the enum.

I want to get the V3 support working again without having to lose the other features of odata V4. Searching by the int value for the enum item seems more reliable than searching for text. Older odata clients (such as kendo) don't support a by-text enum filtering method.


Solution

  • to do that in OData v4, we can enable the EnumPrefixFree in the initial webapi configuration, so we dont have to write the full enum namespace as prefix :

    public static void Register(HttpConfiguration config)
    {
        // ...
        config.EnableEnumPrefixFree(enumPrefixFree: true);
        config.MapODataServiceRoute("odata", "odata", YourEdmModem);
        // ...
    }
    

    then, we can filter any enum by String or Int value :

    $filter=Status eq 'single'
    

    or

    $filter=Status eq 1
    

    hope this helps.