Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

GET handling in /v1/validate #41

Open
dbrgn opened this issue Dec 8, 2019 · 6 comments
Open

GET handling in /v1/validate #41

dbrgn opened this issue Dec 8, 2019 · 6 comments
Assignees

Comments

@dbrgn
Copy link
Contributor

dbrgn commented Dec 8, 2019

A GET Request to /v1/validate returns 404 Not Found, but it should return 405 Method Not Allowed.

@gidsi
Copy link
Member

gidsi commented Dec 8, 2019

Shall we do the same for DELETE, PATCH, etc. usw. i mean it is "more right" but i usually haven't seen it in the wild.

@dbrgn
Copy link
Contributor Author

dbrgn commented Dec 8, 2019

We could, but for those it's much less relevant. I often "explore" RESTful APIs by simply GETing an URL. If it returns 404, I'd assume that the resource doesn't exist. If it returns 405, I know that I'm using the wrong method.

Usually these things are handled even by the most simple web frameworks. You register a POST handler for a URL, then it knows that other methods should return 405, and will also generate a proper OPTIONS response. Of course the API works without that, but I'd not consider it RESTful. (It doesn't need to be, but I find RESTful APIs very useful.)

Aren't there commonly used libraries that offer this for Go?

@gidsi
Copy link
Member

gidsi commented Dec 8, 2019

We could, but for those it's much less relevant. I often "explore" RESTful APIs by simply GETing an URL. If it returns 404, I'd assume that the resource doesn't exist. If it returns 405, I know that I'm using the wrong method.

Usually these things are handled even by the most simple web frameworks. You register a POST handler for a URL, then it knows that other methods should return 405, and will also generate a proper OPTIONS response. Of course the API works without that, but I'd not consider it RESTful. (It doesn't need to be, but I find RESTful APIs very useful.)

Aren't there commonly used libraries that offer this for Go?

There are, but this one is very very lightweight and small. I wanted to start with it since it does.
The 405 behavior would be easy to implement too, but maybe we need something bigger.

@dbrgn
Copy link
Contributor Author

dbrgn commented Dec 8, 2019

In Python I usually use something like Bottle or Flask, which are very small and don't get in your way 🙂 (Bottle is just this file, a bit more than 4000 LOC including comments and empty lines.) I'm not familiar with the golang micro-webframework landscape though.

@gidsi
Copy link
Member

gidsi commented Dec 8, 2019

In Python I usually use something like Bottle or Flask, which are very small and don't get in your way slightly_smiling_face (Bottle is just this file, a bit more than 4000 LOC including comments and empty lines.) I'm not familiar with the golang micro-webframework landscape though.

goji is about a thousand including all type definitions. Its using the basic golang functions and focusing on composition and keeping the api stable.

But anyways, that's not what i would like to focus on, i would like to focus on making it easily accessible. For instance i would like to redirect the root to something like swagger ui and make it easy to generate clients instead of letting people run around in the api itself (but of course doing it RESTful).

@dbrgn
Copy link
Contributor Author

dbrgn commented Dec 8, 2019

I don't mind generated clients, although I don't use them myself. But the API is a contract, it should always be well-defined and behave according to the REST principles 🙂 Using custom helpers for things like OPTIONS is fine for me, although that's something I usually delegate to a microframework.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants