Do one atomic update to the cookie jar for all request and responses.

This commit is contained in:
Michael Dunn 2019-01-26 22:13:32 -06:00
parent c33f27de04
commit 8490ccbe93

View file

@ -184,8 +184,9 @@ performRequest req = do
updateWithResponseCookies cj responses = do updateWithResponseCookies cj responses = do
now <- getCurrentTime now <- getCurrentTime
bss <- Client.brConsume $ Client.responseBody fRes bss <- Client.brConsume $ Client.responseBody fRes
let fRes' = fRes { Client.responseBody = BSL.fromChunks bss } let fRes' = fRes { Client.responseBody = BSL.fromChunks bss }
mapM_ (atomically . updateCookieJar now) $ Client.hrRedirects responses <> [(fReq, fRes')] allResponses = Client.hrRedirects responses <> [(fReq, fRes')]
atomically $ mapM_ (updateCookieJar now) allResponses
return fRes' return fRes'
where where
updateCookieJar :: UTCTime -> (Client.Request, Client.Response BSL.ByteString) -> STM () updateCookieJar :: UTCTime -> (Client.Request, Client.Response BSL.ByteString) -> STM ()