mirror of
https://github.com/aria2/aria2.git
synced 2025-04-05 13:37:40 +03:00
2009-10-27 Tatsuhiro Tsujikawa <t-tujikawa@users.sourceforge.net>
If user name is embedded but password is missing in URI, first resolve password using .netrc. If password is found in .netrc, then use it as password. If not, use the password specified in --ftp-passwd. * src/AuthConfigFactory.cc * src/Request.cc * src/Request.h * test/AuthConfigFactoryTest.cc
This commit is contained in:
parent
cda8b2e343
commit
14a47f43f8
5 changed files with 67 additions and 1 deletions
|
@ -170,6 +170,29 @@ void AuthConfigFactoryTest::testCreateAuthConfig_ftp()
|
|||
req->setUrl("ftp://aria2user:aria2password@localhost/download/aria2-1.0.0.tar.bz2");
|
||||
CPPUNIT_ASSERT_EQUAL(std::string("aria2user:aria2password"),
|
||||
factory.createAuthConfig(req, &option)->getAuthText());
|
||||
|
||||
// username in URI, but no password. We have DefaultAuthenticator
|
||||
// but username is not aria2user
|
||||
req->setUrl("ftp://aria2user@localhost/download/aria2-1.0.0.tar.bz2");
|
||||
CPPUNIT_ASSERT_EQUAL(std::string("aria2user:userDefinedPassword"),
|
||||
factory.createAuthConfig(req, &option)->getAuthText());
|
||||
|
||||
// Recreate netrc with entry for user aria2user
|
||||
netrc.reset(new Netrc());
|
||||
netrc->addAuthenticator
|
||||
(SharedHandle<Authenticator>(new Authenticator("localhost",
|
||||
"aria2user",
|
||||
"netrcpass",
|
||||
"netrcacct")));
|
||||
factory.setNetrc(netrc);
|
||||
// This time, we can find same username "aria2user" in netrc, so the
|
||||
// password "netrcpass" is used, instead of "userDefinedPassword"
|
||||
CPPUNIT_ASSERT_EQUAL(std::string("aria2user:netrcpass"),
|
||||
factory.createAuthConfig(req, &option)->getAuthText());
|
||||
// No netrc entry for host mirror, so "userDefinedPassword" is used.
|
||||
req->setUrl("ftp://aria2user@mirror/download/aria2-1.0.0.tar.bz2");
|
||||
CPPUNIT_ASSERT_EQUAL(std::string("aria2user:userDefinedPassword"),
|
||||
factory.createAuthConfig(req, &option)->getAuthText());
|
||||
}
|
||||
|
||||
void AuthConfigFactoryTest::testUpdateBasicCred()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue