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

Preserve query param value if named route param nil #1676

Merged
merged 1 commit into from
Feb 13, 2022

Conversation

jkowens
Copy link
Member

@jkowens jkowens commented Jan 8, 2021

Optional named route params overwrite a query param of the same name with nil if not included. Fixes #1666.

Optional named route params would overwrite a query param of the same
name with nil if not included
@jkowens jkowens requested a review from namusyaka January 8, 2021 06:57
@namusyaka
Copy link
Member

Well, do we need to follow up on backward-compatibility between 1.4.x and 2.x? The current behavior looks reasonable to me.

@jkowens
Copy link
Member Author

jkowens commented Jan 8, 2021

Good question, I don't know. I'm trying to think of a scenario where it would be necessary or easier to use query params instead of an optional named route parameter. Maybe the old behavior was accidental.

@synecy would you like to weigh in on this?

@jkowens
Copy link
Member Author

jkowens commented Jan 8, 2021

@namusyaka I'm thinking it might be a nice feature if I had to dynamically build links or form data to use query params, but also to have the option of creating direct links using the (optional) named route params.

I suppose you could just create two separate routes if that was they case tho. One without the param and one with the named parameter being required.

@namusyaka
Copy link
Member

Should it be released as a new feature?

I'm sorry, but I'm still thinking that the feature is not useful to me..
Could you write down your design with code examples?

@jkowens
Copy link
Member Author

jkowens commented Feb 14, 2021

@namusyaka I honestly don't feel that strongly about this feature. I'm happy to close this PR and #1666 as a non-issue. I think if this was an issue, the workaround would be to just define an additional route without the optional named route parameters.

@synecy
Copy link

synecy commented Feb 15, 2021

If I recall, our use case was something like this:

/test/123-123-123
/test?user_id[]=123-123-123&user_id[]=456-456-456

which no longer works in 2.x, however we've since added workarounds by either adding multiple routes or manually copying from rack.request.query_hash to restore original behavior. I think the problem with adding new routes is that if you have multiple optionals like:

/?:one?/something/?:two?/test

the number of routes you have to add in order to support every possible case gets out of hand pretty quick.

@namusyaka
Copy link
Member

@synecy Thanks for your explanation. I got your pain point on v2.x.x.

@jkowens Your patch looks reasonable to me. Merging.

@namusyaka namusyaka merged commit e9b3d3f into sinatra:master Feb 13, 2022
@namusyaka namusyaka added this to the v2.1.1 milestone Feb 13, 2022
@jkowens
Copy link
Member Author

jkowens commented Feb 14, 2022

Hey thanks @namusyaka. As @dentarg mentioned, I have already created a 2.2.0 tag on master.

@namusyaka namusyaka modified the milestones: v2.1.1, v3.0.0 Feb 15, 2022
@namusyaka
Copy link
Member

I marked this as v3.0.0. Will cut a new release based on the v2.2.0 tag.
@jkowens Could you add this change in CHANGELOG?

@namusyaka
Copy link
Member

Released:

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

Successfully merging this pull request may close these issues.

1.4 and 2.x backwards compatibility issue with route params and query strings
3 participants