-
-
Notifications
You must be signed in to change notification settings - Fork 2.2k
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
[proposal] Map URL params to struct #1162
Comments
@kolaente I believe this came up earlier as well. Do you mind looking at the existing PR/issues? I don't remember what we concluded but I am open for PR and any discussion around that - if it make sense. |
@vishr There was a pr #973 which got reverted until issues with #980 and #989 get addressed. #980 seems to be merged, #989 was merged and then reverted. I've implemented the feature into my application using echo's functions and it seems to work without any issues. (The code is under https://git.kolaente.de/vikunja/api/src/branch/master/routes/crud/paramBinder.go#L15) Concerning #989: As far as I tested it, it binds only if it finds params in the url and doesn't error out if it doesn't (The way you'd expect it). Also as my implementation calls the default binder, all values are bound to their struct methods. |
@kolaente Why don't you send a PR? |
@vishr I thought discussing this first would be better, I'll send one right away! |
@kolaente Does it work with older issues related to a similar PR? |
I belive there was an issue with earlier implementation when binding to map or slice instead of struct. Eg: |
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions. |
Fixed via #1165 |
First of all, thank you very much for echo, I've used it in several projects and really like it so far!
For my current project I have an URL structure like this:
/some/:id/and/:more/to/:come
for some endpoints and something like/another/:id/
where both of these endpoints use the same interface handler on a struct which then calls some functions on that struct and so on. As the handler is abstract, I couldn't set the url params directly in the handler, so I started implementing a custom binder, which would enable you to define a struct like so:The binder would then map the values of the url params in
/some/:id/and/:more/to/:come
to their respective values in the struct.When I was about half way through implementing this as a custom binder, I realized 95% of my custom binder was already done with
(b *DefaultBinder) bindData()
, so I tried to implement this directly into the standard binder and it worked pretty well. I did something like this (at the end ofbindData()
, right before L75):No need to reinvent the wheel, I thought.
My question now is: Should I send a PR to "really" implement this feature? Is the way I implemented it pure garbage? Or would it be better to implement it separately on my own as a custom binder?
I thought this can be useful for others, so I shared it. This issue is a general one to discuss, as the feature is probably a pretty big one, so I thought it'd be better to create an issue first and discuss a bit instead of sending a pr right away.
The text was updated successfully, but these errors were encountered: