Commit 3cbcfa2d authored by Martin Storsjö's avatar Martin Storsjö

http: Clear the old URLContext pointer when closed

This fixes issues with opening http urls that have authentication
or redirects, introduced in commit e999b641.
Signed-off-by: 's avatarMartin Storsjö <martin@martin.st>
parent b7c3772b
...@@ -161,6 +161,7 @@ static int http_open_cnx(URLContext *h) ...@@ -161,6 +161,7 @@ static int http_open_cnx(URLContext *h)
if ((cur_auth_type == HTTP_AUTH_NONE || s->auth_state.stale) && if ((cur_auth_type == HTTP_AUTH_NONE || s->auth_state.stale) &&
s->auth_state.auth_type != HTTP_AUTH_NONE && attempts < 4) { s->auth_state.auth_type != HTTP_AUTH_NONE && attempts < 4) {
ffurl_close(hd); ffurl_close(hd);
s->hd = hd = NULL;
goto redo; goto redo;
} else } else
goto fail; goto fail;
...@@ -169,6 +170,7 @@ static int http_open_cnx(URLContext *h) ...@@ -169,6 +170,7 @@ static int http_open_cnx(URLContext *h)
if ((cur_proxy_auth_type == HTTP_AUTH_NONE || s->proxy_auth_state.stale) && if ((cur_proxy_auth_type == HTTP_AUTH_NONE || s->proxy_auth_state.stale) &&
s->proxy_auth_state.auth_type != HTTP_AUTH_NONE && attempts < 4) { s->proxy_auth_state.auth_type != HTTP_AUTH_NONE && attempts < 4) {
ffurl_close(hd); ffurl_close(hd);
s->hd = hd = NULL;
goto redo; goto redo;
} else } else
goto fail; goto fail;
...@@ -177,6 +179,7 @@ static int http_open_cnx(URLContext *h) ...@@ -177,6 +179,7 @@ static int http_open_cnx(URLContext *h)
&& location_changed == 1) { && location_changed == 1) {
/* url moved, get next */ /* url moved, get next */
ffurl_close(hd); ffurl_close(hd);
s->hd = hd = NULL;
if (redirects++ >= MAX_REDIRECTS) if (redirects++ >= MAX_REDIRECTS)
return AVERROR(EIO); return AVERROR(EIO);
/* Restart the authentication process with the new target, which /* Restart the authentication process with the new target, which
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment