[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Bug-wget] [Wget-Bug][PATCH] Disable automatic wget headers
From: |
Darshit Shah |
Subject: |
Re: [Bug-wget] [Wget-Bug][PATCH] Disable automatic wget headers |
Date: |
Fri, 15 Mar 2019 19:00:59 +0100 |
User-agent: |
NeoMutt/20180716 |
Hi Adham,
Please send responses to the mailing list.
* adham elkarn <address@hidden> [190315 18:43]:
> Hi Darnir,
>
> Thank you for your answer.
>
> This is my first patch so i thank you also for your patience.
>
> I understood your implementation but i want to be sure. A command like:
>
> wget <url> --disable-header="User-Agent" --disable-header="Accept" is
> equivalent to :
>
> wget <url> --header=User-Agent --header=Accept.
No, that leads to confusion. It should be:
wget <url> --header="User-Agent: " --header="Accept: "
>
> Also would you keep the --no-headers option? I think it allows someone that
> doesn't know what are the default request headers remove them all.
I am not too keen on it. The default request headers can be mentioned in the
manual. Adding new options incurs a maintenance overhead.
>
> Of course the previous patch will be modified.
>
>
> Envoyé à partir de Outlook<http://aka.ms/weboutlook>
>
>
> ________________________________
> De : Darshit Shah <address@hidden>
> Envoyé : vendredi 15 mars 2019 11:18
> À : adham elkarn
> Cc : address@hidden; address@hidden
> Objet : Re: [Bug-wget] [Wget-Bug][PATCH] Disable automatic wget headers
>
> Hi Afham,
>
> Thanks for working on this bug. However, I am not convinced that this is the
> best way of implementing this feature.
>
> I would rather that we have a `--disable-header` switch which takes as input
> the names of the headers that should be disabled. This way it is more
> flexible.
> Simultaneously, it would be nice if you would also implement a parallel
> feature
> in `--header` where the input of "header-name: " will cause <header-name> to
> not be added to the request headers. This allows users to use the existing
> `--header` switch as well.
>
> Also, in the current implementation, I would prefer that you disabled the
> generation of the header itself, rather than removing it at a later stage.
> That
> is just inefficient.
>
> * adham elkarn <address@hidden> [190315 10:26]:
> > From: a-elk <address@hidden>
> >
> >
> > Disable automatic wget headers.
> >
> > *options.h: added no-headers member
> > *http.c: removed default headers
> > *main.c: added new option noheaders, added help description
> > *init.c: adde new option noheaders
> >
> > >From bug #54769 (https://savannah.gnu.org/bugs/?54769).
> > Some servers doesn't handle well some headers. A --no-headers options will
> > ensure a request will not include default
> > defaut headers. This option disables default headers except Accept header
> > and Host header
> >
> > Signed-off-by: Moises Torres, Adham El karn
> > ---
> > src/http.c | 8 ++++++++
> > src/init.c | 1 +
> > src/main.c | 3 +++
> > src/options.h | 1 +
> > 5 files changed, 14 insertions(+)
> >
> > diff --git a/src/http.c b/src/http.c
> > index 304a2f86..e4bcbf27 100644
> > --- a/src/http.c
> > +++ b/src/http.c
> > @@ -3259,6 +3259,14 @@ gethttp (const struct url *u, struct url
> > *original_url, struct http_stat *hs,
> > ),
> > rel_value);
> >
> > + /* Remove default headers */
> > + if (opt.no_headers)
> > + {
> > + int i;
> > + for (i = 0; i < req->hcount; i++)
> > + request_remove_header(req, req->headers[i].name);
> > + }
> > +
> > /* Add the user headers. */
> > if (opt.user_headers)
> > {
> > diff --git a/src/init.c b/src/init.c
> > index 9b6665a6..ae2adeff 100644
> > --- a/src/init.c
> > +++ b/src/init.c
> > @@ -262,6 +262,7 @@ static const struct {
> > { "netrc", &opt.netrc, cmd_boolean },
> > { "noclobber", &opt.noclobber, cmd_boolean },
> > { "noconfig", &opt.noconfig, cmd_boolean },
> > + { "noheaders", &opt.no_headers, cmd_boolean},
> > { "noparent", &opt.no_parent, cmd_boolean },
> > { "noproxy", &opt.no_proxy, cmd_vector },
> > { "numtries", &opt.ntry, cmd_number_inf },/*
> > deprecated*/
> > diff --git a/src/main.c b/src/main.c
> > index 65b7f3f3..92f87171 100644
> > --- a/src/main.c
> > +++ b/src/main.c
> > @@ -377,6 +377,7 @@ static struct cmdline_option option_data[] =
> > { "no", 'n', OPT__NO, NULL, required_argument },
> > { "no-clobber", 0, OPT_BOOLEAN, "noclobber", -1 },
> > { "no-config", 0, OPT_BOOLEAN, "noconfig", -1},
> > + { "no-headers", 0, OPT_BOOLEAN, "noheaders", no_argument},
> > { "no-parent", 0, OPT_BOOLEAN, "noparent", -1 },
> > { "output-document", 'O', OPT_VALUE, "outputdocument", -1 },
> > { "output-file", 'o', OPT_VALUE, "logfile", -1 },
> > @@ -1025,6 +1026,8 @@ Recursive accept/reject:\n"),
> > -X, --exclude-directories=LIST list of excluded directories\n"),
> > N_("\
> > -np, --no-parent don't ascend to the parent
> > directory\n"),
> > + N_("\
> > + --no-headers don't include default headers\n"),
> > "\n",
> > N_("Email bug reports, questions, discussions to <address@hidden>\n"),
> > N_("and/or open issues at
> > https://savannah.gnu.org/bugs/?func=additem&group=wget.\n")
> > diff --git a/src/options.h b/src/options.h
> > index 881e2b2e..65055ad8 100644
> > --- a/src/options.h
> > +++ b/src/options.h
> > @@ -147,6 +147,7 @@ struct options
> > char *http_user; /* HTTP username. */
> > char *http_passwd; /* HTTP password. */
> > char **user_headers; /* User-defined header(s). */
> > + bool no_headers; /* Don'include default headers */
> > bool http_keep_alive; /* whether we use keep-alive */
> >
> > bool use_proxy; /* Do we use proxy? */
> > --
> > 2.17.1
> >
> >
> >
>
> --
> Thanking You,
> Darshit Shah
> PGP Fingerprint: 7845 120B 07CB D8D6 ECE5 FF2B 2A17 43ED A91A 35B6
--
Thanking You,
Darshit Shah
PGP Fingerprint: 7845 120B 07CB D8D6 ECE5 FF2B 2A17 43ED A91A 35B6
signature.asc
Description: PGP signature