From: Patrick Ohly <patrick.ohly@intel.com>
To: Ingo Flaschberger <ingo.flaschberger@gmail.com>, yocto@yoctoproject.org
Subject: Re: [meta-swupd][PATCH 1/1] bundles.py: allow username/password encoded in URLs
Date: Tue, 09 Jan 2018 17:57:30 +0100 [thread overview]
Message-ID: <1515517050.6718.15.camel@intel.com> (raw)
In-Reply-To: <8524e767-204b-2e4f-9971-d0c51862de0c@gmail.com>
On Thu, 2017-12-21 at 00:18 +0100, Ingo Flaschberger wrote:
> Dear Patrick,
>
> this doesn't work:
> 0162: """
> 0163: parsed_url = urllib.parse.urlsplit(url)
> 0164: if parsed_url.username != None:
> 0165: # Use the netloc with just the hostname, without
> username/password.
> *** 0166: parsed_url.netloc = parsed_url.hostname
> 0167: # The username/password are installed permanently
> in
> the urllib.request module
> 0168: # for future use with all URLs beneath url.
> 0169: manager =
> urllib.request.HTTPPasswordMgrWithDefaultRealm()
> 0170: manager.add_password(None, parsed_url,
> parsed_url.username, parsed_url.password)
> Exception: AttributeError: can't set attribute
Looks like netloc is a read-only attribute. That means one has to
construct a new urllib.parse.SplitResult instead of updating the old
one.
> Using hostname as netloc will also remove an additional portnumber -
> could this be a problem?
Yes, that's also something that needs to be fixed.
Can you update the patch as shown below, test it, and it if works send
the final version to the list? Obviously I am not doing a good job with
posting code that I can't test :-/
Am 20.12.2017 um 16:50 schrieb Patrick Ohly:
> > Downloading content and version information via HTTP may need a
> > username/password for basic authentication. To support this,
> > SWUPD_VERSION_URL and SWUPD_CONTENT_URL can now contain URLs of the
> > form http(s)://<user>:<password>@<host>/.
> >
> > Original patch from: Ingo Flaschberger <ingo.flaschberger@gmail.com
> > >
> >
> > Signed-off-by: Patrick Ohly <patrick.ohly@intel.com>
> > ---
> > lib/swupd/bundles.py | 26 ++++++++++++++++++++++++--
> > 1 file changed, 24 insertions(+), 2 deletions(-)
> >
> > diff --git a/lib/swupd/bundles.py b/lib/swupd/bundles.py
> > index e1eec5a..48c7455 100644
> > --- a/lib/swupd/bundles.py
> > +++ b/lib/swupd/bundles.py
> > @@ -5,6 +5,7 @@ import subprocess
> > import shutil
> > import urllib.request
> > import urllib.error
> > +import urllib.parse
> > from bb.utils import export_proxies
> > from oe.package_manager import RpmPM
> > from oe.package_manager import OpkgPM
> > @@ -153,6 +154,27 @@ def copy_bundle_contents(d):
> > for bndl in bundles:
> > stage_empty_bundle(d, bndl)
> >
> > +def handle_plain_auth(url):
> > + """
> > + Check for special urls with username/password (as in http://us
> > er:password@host/),
> > + extract those and install an auth handler which will provide
> > them
> > + to the HTTP server when needed. Returns the URL that is to be
> > instead of the original one.
> > + """
> > + parsed_url = urllib.parse.urlsplit(url)
> > + if parsed_url.username != None:
> > + # Use the netloc with just the hostname, without
> > username/password.
> > + parsed_url.netloc = parsed_url.hostname
Instead:
netloc = parsed_url.hostname
if parsed_url.port is not None:
netloc += ":%d" % parsed_url.port
new_url = urllib.parse.SplitResult(parsed_url.scheme, netloc, parsed_url.path, parsed_url.query, parsed_url.fragment)
> > + # The username/password are installed permanently in the
> > urllib.request module
> > + # for future use with all URLs beneath url.
> > + manager = urllib.request.HTTPPasswordMgrWithDefaultRealm()
> > + manager.add_password(None, parsed_url,
> > parsed_url.username, parsed_url.password)
> > + authHandler = urllib.request.HTTPBasicAuthHandler(manager)
> > + opener = urllib.request.build_opener(authHandler)
> > + urllib.request.install_opener(opener)
> > + return urllib.parse.urlunsplit(new_source)
Instead:
return urllib.parse.urlunsplit(new_url)
--
Best Regards, Patrick Ohly
The content of this message is my personal opinion only and although
I am an employee of Intel, the statements I make here in no way
represent Intel's position on the issue, nor am I authorized to speak
on behalf of Intel on this matter.
next prev parent reply other threads:[~2018-01-09 16:57 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-03-23 15:04 [meta-swupd] allow username/password encoded in SWUPD_VERSION_URL and SWUPD_CONTENT_URL Ingo Flaschberger
2017-03-24 9:04 ` Patrick Ohly
2017-03-25 20:14 ` Ingo Flaschberger
2017-12-20 15:50 ` Patrick Ohly
2017-12-20 15:50 ` [meta-swupd][PATCH 1/1] bundles.py: allow username/password encoded in URLs Patrick Ohly
2017-12-20 23:18 ` Ingo Flaschberger
2018-01-09 16:57 ` Patrick Ohly [this message]
2018-01-09 18:28 ` Ingo Flaschberger
2018-01-10 9:58 ` Patrick Ohly
2018-02-24 23:31 ` Ingo Flaschberger
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1515517050.6718.15.camel@intel.com \
--to=patrick.ohly@intel.com \
--cc=ingo.flaschberger@gmail.com \
--cc=yocto@yoctoproject.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.