-
Notifications
You must be signed in to change notification settings - Fork 84
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
Add Snap.Cookie with a Cookie type using lenses #287
base: master
Are you sure you want to change the base?
Conversation
This also implements SameSite for cookies. The change should be mostly transparent for code using the old Cookie type. The functions that use Cookie now use a IsCookie typeclass instead.
No opinion on the actual feature here, but can we please not include lens as a dependency in snap-core? It's a massive set of additional transitive dependencies. |
The main snap package already depends on lens, does snap-core get used without it a lot? Anyhow, it would be quite possible to drop the dependency and add some module |
Not that Hackage download numbers are super reliable (because of CDNs, etc) but according to those numbers, 20% of the usage of |
Agree with @tom-audm. Depending on lens in snap-core is a no-go. I'm not quite sure what I think about the tradeoff between two |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for taking so long to get to this, I'm on pandemic paternity leave and am not even looking at computers right now.
I'm definitely in favour of adding this feature. Lens as a dep for snap-core
gets a downvote from me though. I'll get to that. Here's the thing, we screwed this up: in almost all of our code we have been careful to not expose our datatype constructors in public interfaces, so that the underlying datatypes can be changed without breaking user code. Somehow we missed this for Cookie
, and now there's a new-ish cookie feature, and ugh.
Can we have this as an action plan?
- remove
Default
instance and dependency - 👍 to "remove old
Cookie
datatype, hide constructor, move to a new module" - 👎 to "lens as a snap-core dep", adding
get
+set
functions instead of lens TH - this will require a major version bump :(
|
||
|
||
------------------------------------------------------------------------------ | ||
instance Default Cookie where |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't love Default
as part of my war against "typeclasses without laws". My argument is usually: "why is writing def
preferable to emptyCookie :: Cookie
"?
This also implements SameSite for cookies.
The change should be mostly transparent for code using the old
Cookie type. The functions that use Cookie now use a IsCookie
typeclass instead.
This change will break code that does not actually use the Cookie value but just passes it along to
isNothing
or the equivalent.rqCookies
is no longer a field so any use of it as a record selector breaks as well but I'm not sure if that's even a concern with user code. I'm hoping that neither is too much of an issue.Any feedback on how I implemented
Snap.Cookie
? It was quite lightweight and I saw no reason to split any of it to an internal module and make re-exports.If Snap would have a major version update with code breakage then I would suggest merging
Snap.Cookie
toSnap.Internal.Http.Types
and make the former just offer re-exports.