* [PATCH] doc: update http.cookieFile with in-memory cookie processing
@ 2024-06-23 21:24 Piotr Szlazak via GitGitGadget
2024-07-09 21:37 ` Piotr Szlazak
` (2 more replies)
0 siblings, 3 replies; 7+ messages in thread
From: Piotr Szlazak via GitGitGadget @ 2024-06-23 21:24 UTC (permalink / raw)
To: git; +Cc: Piotr Szlazak, Piotr Szlazak
From: Piotr Szlazak <piotr.szlazak@gmail.com>
Information added how to enable in-memory cookies
processing. Cookies from server will be accepted and send
back in successive requests within same connection.
At the moment documentation only mentions how to read
cookies from the given file and how to save them to the file
using http.saveCookies.
curl / libcurl will process cookies in memory if file name
is blank. Check curl manpage:
https://curl.se/docs/manpage.html#-b
This is described here in more details:
https://everything.curl.dev/http/cookies/engine.html
And also explained here:
https://www.youtube.com/watch?v=V5vZWHP-RqU&t=11459s
Git documentation was updated to include suggestion how to
enable this by setting empty value for http.cookieFile.
Signed-off-by: Piotr Szlazak <piotr.szlazak@gmail.com>
---
Update http.cookieFile with in-memory cookie processing
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-git-1733%2Fpszlazak%2Fdocumentation-cookieFile-in-memory-v1
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-git-1733/pszlazak/documentation-cookieFile-in-memory-v1
Pull-Request: https://github.com/git/git/pull/1733
Documentation/config/http.txt | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/Documentation/config/http.txt b/Documentation/config/http.txt
index 2d4e0c9b869..228bed32ec1 100644
--- a/Documentation/config/http.txt
+++ b/Documentation/config/http.txt
@@ -78,10 +78,10 @@ http.extraHeader::
http.cookieFile::
The pathname of a file containing previously stored cookie lines,
- which should be used
- in the Git http session, if they match the server. The file format
- of the file to read cookies from should be plain HTTP headers or
- the Netscape/Mozilla cookie file format (see `curl(1)`).
+ which should be used in the Git http session, if they match the server.
+ The file format of the file to read cookies from should be plain HTTP
+ headers or the Netscape/Mozilla cookie file format (see `curl(1)`).
+ Set it to empty value, to enable in-memory cookies processing.
NOTE that the file specified with http.cookieFile is used only as
input unless http.saveCookies is set.
base-commit: 66ac6e4bcd111be3fa9c2a6b3fafea718d00678d
--
gitgitgadget
^ permalink raw reply related [flat|nested] 7+ messages in thread* Re: [PATCH] doc: update http.cookieFile with in-memory cookie processing 2024-06-23 21:24 [PATCH] doc: update http.cookieFile with in-memory cookie processing Piotr Szlazak via GitGitGadget @ 2024-07-09 21:37 ` Piotr Szlazak 2024-07-09 22:30 ` Junio C Hamano 2024-07-09 23:05 ` Junio C Hamano 2024-07-11 8:36 ` [PATCH v2] " Piotr Szlazak via GitGitGadget 2 siblings, 1 reply; 7+ messages in thread From: Piotr Szlazak @ 2024-07-09 21:37 UTC (permalink / raw) To: Piotr Szlazak via GitGitGadget, gitster; +Cc: git, piotr.szlazak On 23.06.2024 23:24, Piotr Szlazak via GitGitGadget wrote: > From: Piotr Szlazak <piotr.szlazak@gmail.com> > > Information added how to enable in-memory cookies > processing. Cookies from server will be accepted and send > back in successive requests within same connection. > > At the moment documentation only mentions how to read > cookies from the given file and how to save them to the file > using http.saveCookies. > > curl / libcurl will process cookies in memory if file name > is blank. Check curl manpage: > https://curl.se/docs/manpage.html#-b > This is described here in more details: > https://everything.curl.dev/http/cookies/engine.html > And also explained here: > https://www.youtube.com/watch?v=V5vZWHP-RqU&t=11459s > > Git documentation was updated to include suggestion how to > enable this by setting empty value for http.cookieFile. > > Signed-off-by: Piotr Szlazak <piotr.szlazak@gmail.com> Hello Junio! Would you be able to take a look at my commit? It's a small update in Documentation/config/http.txt, where I wanted to share how to enable in-memory HTTP cookies processing. It's more curl/libcurl related thing, but worth to be known by Git users. Regards! -- Piotr Szlazak > --- > Update http.cookieFile with in-memory cookie processing Published-As: > https://github.com/gitgitgadget/git/releases/tag/pr-git-1733%2Fpszlazak%2Fdocumentation-cookieFile-in-memory-v1Fetch-It-Via: > git fetch https://github.com/gitgitgadget/git > pr-git-1733/pszlazak/documentation-cookieFile-in-memory-v1 > Pull-Request: https://github.com/git/git/pull/1733 > Documentation/config/http.txt | 8 ++++---- 1 file changed, 4 > insertions(+), 4 deletions(-) diff --git > a/Documentation/config/http.txt b/Documentation/config/http.txt index > 2d4e0c9b869..228bed32ec1 100644 --- a/Documentation/config/http.txt > +++ b/Documentation/config/http.txt @@ -78,10 +78,10 @@ > http.extraHeader:: http.cookieFile:: The pathname of a file containing > previously stored cookie lines, - which should be used - in the Git > http session, if they match the server. The file format - of the file > to read cookies from should be plain HTTP headers or - the > Netscape/Mozilla cookie file format (see `curl(1)`). + which should be > used in the Git http session, if they match the server. + The file > format of the file to read cookies from should be plain HTTP + headers > or the Netscape/Mozilla cookie file format (see `curl(1)`). + Set it > to empty value, to enable in-memory cookies processing. NOTE that the > file specified with http.cookieFile is used only as input unless > http.saveCookies is set. base-commit: > 66ac6e4bcd111be3fa9c2a6b3fafea718d00678d ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] doc: update http.cookieFile with in-memory cookie processing 2024-07-09 21:37 ` Piotr Szlazak @ 2024-07-09 22:30 ` Junio C Hamano 0 siblings, 0 replies; 7+ messages in thread From: Junio C Hamano @ 2024-07-09 22:30 UTC (permalink / raw) To: Piotr Szlazak Cc: Piotr Szlazak via GitGitGadget, git, Patrick Steinhardt, Jeff King, brian m. carlson Piotr Szlazak <piotr.szlazak@gmail.com> writes: > Hello Junio! > Would you be able to take a look at my commit? Please do not specifically name me. If I did not respond, that was because I considered it was outside my area of expertise, so pinging me would not help all that much. CC'ed folks who touched http.c (where the configuration is used) in the past 6 months to ask for their help. Thanks. ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] doc: update http.cookieFile with in-memory cookie processing 2024-06-23 21:24 [PATCH] doc: update http.cookieFile with in-memory cookie processing Piotr Szlazak via GitGitGadget 2024-07-09 21:37 ` Piotr Szlazak @ 2024-07-09 23:05 ` Junio C Hamano 2024-07-11 9:18 ` Piotr Szlazak 2024-07-11 8:36 ` [PATCH v2] " Piotr Szlazak via GitGitGadget 2 siblings, 1 reply; 7+ messages in thread From: Junio C Hamano @ 2024-07-09 23:05 UTC (permalink / raw) To: Piotr Szlazak via GitGitGadget; +Cc: git, Piotr Szlazak "Piotr Szlazak via GitGitGadget" <gitgitgadget@gmail.com> writes: > http.cookieFile:: > The pathname of a file containing previously stored cookie lines, > - which should be used > - in the Git http session, if they match the server. The file format > - of the file to read cookies from should be plain HTTP headers or > - the Netscape/Mozilla cookie file format (see `curl(1)`). > + which should be used in the Git http session, if they match the server. > + The file format of the file to read cookies from should be plain HTTP > + headers or the Netscape/Mozilla cookie file format (see `curl(1)`). With line wrapping it is hard to see if there is any change above here, but I assume there is none? > + Set it to empty value, to enable in-memory cookies processing. Is it understandable what "in-memory cookies processing" means to expected audience of this manual page? I somehow doubt it (I certainly do not know what you wanted it to mean). https://curl.se/libcurl/c/CURLOPT_COOKIEFILE.html has this to say: By passing the empty string ("") to this option, you enable the cookie engine without reading any initial cookies. But http.cookiefile is also used for CURLOPT_COOKIEJAR when http.savecookies is true. Its documentation page does not say what would happen if you give an empty string to it. So, a casual one-line mention you added is a bit irresponsible. At least you should warn against setting http.savecookies if the user chooses to use "" for this, or better yet, fix the codepath to use http.savecookies to prevent us from writing to a file with an empty filename. Also the libcURL documentation for CURLOPT_COOKIEFILE has another thing that is a bit worrysome: If you tell libcurl the filename is "-" (just a single minus sign), libcurl instead reads from stdin. So you can easily get your git get stuck by doing git -c http.cookiefile=- fetch https://..... as libcURL will want to read from your stdin, while you are waiting for the fetch to finish and are not typing anything? ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] doc: update http.cookieFile with in-memory cookie processing 2024-07-09 23:05 ` Junio C Hamano @ 2024-07-11 9:18 ` Piotr Szlazak 0 siblings, 0 replies; 7+ messages in thread From: Piotr Szlazak @ 2024-07-11 9:18 UTC (permalink / raw) To: Junio C Hamano, Piotr Szlazak via GitGitGadget; +Cc: git On 10.07.2024 01:05, Junio C Hamano wrote: > "Piotr Szlazak via GitGitGadget" <gitgitgadget@gmail.com> writes: > >> http.cookieFile:: >> The pathname of a file containing previously stored cookie lines, >> - which should be used >> - in the Git http session, if they match the server. The file format >> - of the file to read cookies from should be plain HTTP headers or >> - the Netscape/Mozilla cookie file format (see `curl(1)`). >> + which should be used in the Git http session, if they match the server. >> + The file format of the file to read cookies from should be plain HTTP >> + headers or the Netscape/Mozilla cookie file format (see `curl(1)`). > With line wrapping it is hard to see if there is any change above > here, but I assume there is none? Sorry for bad formatting, I'm still learning. > >> + Set it to empty value, to enable in-memory cookies processing. > Is it understandable what "in-memory cookies processing" means to > expected audience of this manual page? I somehow doubt it (I > certainly do not know what you wanted it to mean). I pushed PATCH 2, this time without curl/libcurl terminology (i.e. without calling it in-memory cookie processing). Hope it helps. I also mentioned there that http.saveCookies has no effect if '' was used for http.cookieFile. Regards! -- Piotr Szlazak > > https://curl.se/libcurl/c/CURLOPT_COOKIEFILE.html has this to say: > > By passing the empty string ("") to this option, you enable the > cookie engine without reading any initial cookies. > > But http.cookiefile is also used for CURLOPT_COOKIEJAR when > http.savecookies is true. Its documentation page does not say what > would happen if you give an empty string to it. > > So, a casual one-line mention you added is a bit irresponsible. At > least you should warn against setting http.savecookies if the user > chooses to use "" for this, or better yet, fix the codepath to use > http.savecookies to prevent us from writing to a file with an empty > filename. > > Also the libcURL documentation for CURLOPT_COOKIEFILE has another > thing that is a bit worrysome: > > If you tell libcurl the filename is "-" (just a single minus > sign), libcurl instead reads from stdin. > > So you can easily get your git get stuck by doing > > git -c http.cookiefile=- fetch https://..... > > as libcURL will want to read from your stdin, while you are waiting > for the fetch to finish and are not typing anything? > ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH v2] doc: update http.cookieFile with in-memory cookie processing 2024-06-23 21:24 [PATCH] doc: update http.cookieFile with in-memory cookie processing Piotr Szlazak via GitGitGadget 2024-07-09 21:37 ` Piotr Szlazak 2024-07-09 23:05 ` Junio C Hamano @ 2024-07-11 8:36 ` Piotr Szlazak via GitGitGadget 2024-07-11 16:05 ` Junio C Hamano 2 siblings, 1 reply; 7+ messages in thread From: Piotr Szlazak via GitGitGadget @ 2024-07-11 8:36 UTC (permalink / raw) To: git Cc: Jeff King, brian m. carlson, Junio C Hamano, Piotr Szlazak, Piotr Szlazak From: Piotr Szlazak <piotr.szlazak@gmail.com> Information added how to enable in-memory cookies processing. Cookies from server will be accepted and send back in successive requests within same connection. At the moment documentation only mentions how to read cookies from the given file and how to save them to the file using http.saveCookies. curl / libcurl will process cookies in memory if file name is blank. Check curl manpage: https://curl.se/docs/manpage.html#-b This is described here in more details: https://everything.curl.dev/http/cookies/engine.html And also explained here: https://www.youtube.com/watch?v=V5vZWHP-RqU&t=11459s Git documentation was updated to include suggestion how to enable this by setting empty value for http.cookieFile. Changes since V1: - better explanation what in-memory processing means - added explanation that http.saveCookies does not work if http.cookieFile was set to empty value Signed-off-by: Piotr Szlazak <piotr.szlazak@gmail.com> --- Update http.cookieFile with in-memory cookie processing Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-git-1733%2Fpszlazak%2Fdocumentation-cookieFile-in-memory-v2 Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-git-1733/pszlazak/documentation-cookieFile-in-memory-v2 Pull-Request: https://github.com/git/git/pull/1733 Range-diff vs v1: 1: 5e9b3924224 ! 1: c4d41b5884d doc: update http.cookieFile with in-memory cookie processing @@ Commit message Git documentation was updated to include suggestion how to enable this by setting empty value for http.cookieFile. + Changes since V1: + - better explanation what in-memory processing means + - added explanation that http.saveCookies does not work + if http.cookieFile was set to empty value + Signed-off-by: Piotr Szlazak <piotr.szlazak@gmail.com> ## Documentation/config/http.txt ## @@ Documentation/config/http.txt: http.extraHeader:: - in the Git http session, if they match the server. The file format - of the file to read cookies from should be plain HTTP headers or - the Netscape/Mozilla cookie file format (see `curl(1)`). +- NOTE that the file specified with http.cookieFile is used only as +- input unless http.saveCookies is set. + which should be used in the Git http session, if they match the server. + The file format of the file to read cookies from should be plain HTTP + headers or the Netscape/Mozilla cookie file format (see `curl(1)`). -+ Set it to empty value, to enable in-memory cookies processing. - NOTE that the file specified with http.cookieFile is used only as - input unless http.saveCookies is set. ++ Set it to empty value (''), to accept only new cookies from the server and ++ send them back in successive requests within same connection. NOTE that the ++ file specified with http.cookieFile is used only as input unless ++ http.saveCookies is set. + + http.saveCookies:: + If set, store cookies received during requests to the file specified by +- http.cookieFile. Has no effect if http.cookieFile is unset. ++ http.cookieFile. Has no effect if http.cookieFile is not set or set to empty ++ value (''). + http.version:: + Use the specified HTTP protocol version when communicating with a server. Documentation/config/http.txt | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/Documentation/config/http.txt b/Documentation/config/http.txt index 2d4e0c9b869..e71ca11c10b 100644 --- a/Documentation/config/http.txt +++ b/Documentation/config/http.txt @@ -78,16 +78,18 @@ http.extraHeader:: http.cookieFile:: The pathname of a file containing previously stored cookie lines, - which should be used - in the Git http session, if they match the server. The file format - of the file to read cookies from should be plain HTTP headers or - the Netscape/Mozilla cookie file format (see `curl(1)`). - NOTE that the file specified with http.cookieFile is used only as - input unless http.saveCookies is set. + which should be used in the Git http session, if they match the server. + The file format of the file to read cookies from should be plain HTTP + headers or the Netscape/Mozilla cookie file format (see `curl(1)`). + Set it to empty value (''), to accept only new cookies from the server and + send them back in successive requests within same connection. NOTE that the + file specified with http.cookieFile is used only as input unless + http.saveCookies is set. http.saveCookies:: If set, store cookies received during requests to the file specified by - http.cookieFile. Has no effect if http.cookieFile is unset. + http.cookieFile. Has no effect if http.cookieFile is not set or set to empty + value (''). http.version:: Use the specified HTTP protocol version when communicating with a server. base-commit: 66ac6e4bcd111be3fa9c2a6b3fafea718d00678d -- gitgitgadget ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH v2] doc: update http.cookieFile with in-memory cookie processing 2024-07-11 8:36 ` [PATCH v2] " Piotr Szlazak via GitGitGadget @ 2024-07-11 16:05 ` Junio C Hamano 0 siblings, 0 replies; 7+ messages in thread From: Junio C Hamano @ 2024-07-11 16:05 UTC (permalink / raw) To: Piotr Szlazak via GitGitGadget Cc: git, Jeff King, brian m. carlson, Piotr Szlazak "Piotr Szlazak via GitGitGadget" <gitgitgadget@gmail.com> writes: > From: Piotr Szlazak <piotr.szlazak@gmail.com> Thanks. > Information added how to enable in-memory cookies > processing. Cookies from server will be accepted and send > back in successive requests within same connection. > > At the moment documentation only mentions how to read > cookies from the given file and how to save them to the file > using http.saveCookies. > > curl / libcurl will process cookies in memory if file name > is blank. Check curl manpage: > https://curl.se/docs/manpage.html#-b > This is described here in more details: > https://everything.curl.dev/http/cookies/engine.html > And also explained here: > https://www.youtube.com/watch?v=V5vZWHP-RqU&t=11459s > > Git documentation was updated to include suggestion how to > enable this by setting empty value for http.cookieFile. > > Changes since V1: > - better explanation what in-memory processing means > - added explanation that http.saveCookies does not work > if http.cookieFile was set to empty value > > Signed-off-by: Piotr Szlazak <piotr.szlazak@gmail.com> > --- Here is how I amended the log message, FYI. doc: update http.cookieFile with in-memory cookie processing Documentation only mentions how to read cookies from the given file and how to save them to the file using http.saveCookies. But underlying libcURL allows the HTTP cookies used only in memory; cookies from the server will be accepted and sent back in successive requests within same connection, by using an empty string as the filename. Document this. Signed-off-by: Piotr Szlazak <piotr.szlazak@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com> A few points to note: - It is our convention to start a proposed log message by describing the current status in present tense ("currently", "at the moment", etc., are not needed). - The observation of the current status is followed by the description of a problem the patch tries to solve. - And then finally we give an order to the codebase to "become like so". - Changes between iterations do not belong to the log message, as the log messages are written for those who run "git log"; to them, our previous iterations do not exist. We describe changes below the "---" lines. > diff --git a/Documentation/config/http.txt b/Documentation/config/http.txt > index 2d4e0c9b869..e71ca11c10b 100644 > --- a/Documentation/config/http.txt > +++ b/Documentation/config/http.txt > @@ -78,16 +78,18 @@ http.extraHeader:: > > http.cookieFile:: > The pathname of a file containing previously stored cookie lines, > - which should be used > - in the Git http session, if they match the server. The file format > - of the file to read cookies from should be plain HTTP headers or > - the Netscape/Mozilla cookie file format (see `curl(1)`). > - NOTE that the file specified with http.cookieFile is used only as > - input unless http.saveCookies is set. > + which should be used in the Git http session, if they match the server. > + The file format of the file to read cookies from should be plain HTTP > + headers or the Netscape/Mozilla cookie file format (see `curl(1)`). > + Set it to empty value (''), to accept only new cookies from the server and > + send them back in successive requests within same connection. NOTE that the > + file specified with http.cookieFile is used only as input unless > + http.saveCookies is set. > > http.saveCookies:: > If set, store cookies received during requests to the file specified by > - http.cookieFile. Has no effect if http.cookieFile is unset. > + http.cookieFile. Has no effect if http.cookieFile is not set or set to empty > + value (''). I reformatted the patch and added minor word-smithing. A few points: - Avoid unnecessary line rewrapping. This file gets formatted into HTML or manpage and formatting tools will take care of filling paragraphs. - Use "an empty string", which is used by other parts of this file and other documentation files under Documentaiton/config/ directory, instead of "empty value". We should fix other instances of "empty value" in the file for consistency but it should be left outside the scope of this patch as #leftoverbits material. Thanks again. diff --git a/Documentation/config/http.txt b/Documentation/config/http.txt index 2d4e0c9b86..bd04ca1c2e 100644 --- a/Documentation/config/http.txt +++ b/Documentation/config/http.txt @@ -82,12 +82,16 @@ http.cookieFile:: in the Git http session, if they match the server. The file format of the file to read cookies from should be plain HTTP headers or the Netscape/Mozilla cookie file format (see `curl(1)`). + Set it to an empty string, to accept only new cookies from + the server and send them back in successive requests within same + connection. NOTE that the file specified with http.cookieFile is used only as input unless http.saveCookies is set. http.saveCookies:: If set, store cookies received during requests to the file specified by - http.cookieFile. Has no effect if http.cookieFile is unset. + http.cookieFile. Has no effect if http.cookieFile is unset, or set to + an empty string. http.version:: Use the specified HTTP protocol version when communicating with a server. ^ permalink raw reply related [flat|nested] 7+ messages in thread
end of thread, other threads:[~2024-07-11 16:05 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2024-06-23 21:24 [PATCH] doc: update http.cookieFile with in-memory cookie processing Piotr Szlazak via GitGitGadget 2024-07-09 21:37 ` Piotr Szlazak 2024-07-09 22:30 ` Junio C Hamano 2024-07-09 23:05 ` Junio C Hamano 2024-07-11 9:18 ` Piotr Szlazak 2024-07-11 8:36 ` [PATCH v2] " Piotr Szlazak via GitGitGadget 2024-07-11 16:05 ` Junio C Hamano
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).