On Stack Overflow and the Eve mailing list, but also in my mailbox and even on Twitter, I get a lot of enquiries on how to build custom endpoints within a Eve-powered RESTful application. Now, since within Eve all endpoints are fully customizable, what they really mean is:
How do I setup endpoints without any binding to a data entity, just connected to a custom method?
They would like to call something like
/mycustomendpoint and get the response from a method they have defined somewhere in the Python sources. The standard endpoint-entity mapping provided by Eve covers 90% of their needs, but sometimes they just need endpoints that have nothing to do with data entities.
This is very easy to achieve. I’m writing it down so I can point people to this post in the future.
Eve is Flask
Eve is a Flask application and I really mean it since it is, in fact, a Flask subclass. Eve adds out-of-the-box RESTful capabilities to the Flask micro-framework. Most of the time you will be happy with just Eve’s own features but remember, the full Flask (and Werkzeug at a lower level) features set is also part of your arsenal.
Whatever you can do with Flask, you can do with Eve
So yes, of course you can easily set some functions to be invoked when a custom endpoint is hit with a request. The following snippet is a slightly modified version of Flask’s very own Quickstart tutorial:
By decorating the
hello_world method with the
route decorator we added a new endpoint to the application. Each time a request to
/hello comes in, it will be routed to our custom method. Of course the regular API endpoints (either defined in
settings.py, passed as a dict at launch, or registered live by calling the
register_resource method) will also be available.
If you have an Eve authentication class securing regular API endpoints, you can apply it to your custom endpoint too. Just add a
Say that you saved the above snippet as run.py and also have your RESTful endpoints properly configured. Launch the script:
You can now point your browser to
http://localhost:5000/hello/ and enjoy the application greeting. Or you can consume any other configured API endpoint.
As all of Flask features are at your fingertips you might as well opt for registering a blueprint, which is what the awesome Eve-Docs extension is doing in order to provide a static HTML
/docs endpoint on top of any Eve powered API.