Message ID | 20200613215808.62675-1-epirat07@gmail.com |
---|---|
State | Superseded |
Headers | show |
Series | [FFmpeg-devel] avformat/icecast: Add option to use TLS connection | expand |
Context | Check | Description |
---|---|---|
andriy/default | pending | |
andriy/make_warn | warning | New warnings during build |
andriy/make | success | Make finished |
andriy/make_fate | success | Make fate finished |
Marvin Scholz: > --- > doc/protocols.texi | 3 +++ > libavformat/icecast.c | 7 ++++++- > 2 files changed, 9 insertions(+), 1 deletion(-) > > diff --git a/doc/protocols.texi b/doc/protocols.texi > index 7aa758541c..32c829d2a3 100644 > --- a/doc/protocols.texi > +++ b/doc/protocols.texi > @@ -520,6 +520,9 @@ audio/mpeg. > This enables support for Icecast versions < 2.4.0, that do not support the > HTTP PUT method but the SOURCE method. > > +@item tls > +Establish a TLS (HTTPS) connection to Icecast. > + > @end table > > @example > diff --git a/libavformat/icecast.c b/libavformat/icecast.c > index 38af16b99e..5073367fd4 100644 > --- a/libavformat/icecast.c > +++ b/libavformat/icecast.c > @@ -43,6 +43,7 @@ typedef struct IcecastContext { > int public; > char *url; > char *user_agent; > + int tls; > } IcecastContext; > > #define DEFAULT_ICE_USER "source" > @@ -62,6 +63,7 @@ static const AVOption options[] = { > { "password", "set password", OFFSET(pass), AV_OPT_TYPE_STRING, { .str = NULL }, 0, 0, E }, > { "content_type", "set content-type, MUST be set if not audio/mpeg", OFFSET(content_type), AV_OPT_TYPE_STRING, { .str = NULL }, 0, 0, E }, > { "legacy_icecast", "use legacy SOURCE method, for Icecast < v2.4", OFFSET(legacy_icecast), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, E }, > + { "tls", "use a TLS connection", OFFSET(tls), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, E }, > { NULL } > }; > > @@ -161,8 +163,11 @@ static int icecast_open(URLContext *h, const char *uri, int flags) > goto cleanup; > } > > + // Check which underlying protocol should be used > + const char *real_proto = (s->tls) ? "https" : "http"; This should give a "mixed declaration and code" compiler warning. > + > // Build new URI for passing to http protocol > - ff_url_join(h_url, sizeof(h_url), "http", auth, host, port, "%s", path); > + ff_url_join(h_url, sizeof(h_url), real_proto, auth, host, port, "%s", path); > // Finally open http proto handler > ret = ffurl_open_whitelist(&s->hd, h_url, AVIO_FLAG_READ_WRITE, NULL, > &opt_dict, h->protocol_whitelist, h->protocol_blacklist, h); >
On 14 Jun 2020, at 0:18, Andreas Rheinhardt wrote: > Marvin Scholz: >> --- >> doc/protocols.texi | 3 +++ >> libavformat/icecast.c | 7 ++++++- >> 2 files changed, 9 insertions(+), 1 deletion(-) >> >> diff --git a/doc/protocols.texi b/doc/protocols.texi >> index 7aa758541c..32c829d2a3 100644 >> --- a/doc/protocols.texi >> +++ b/doc/protocols.texi >> @@ -520,6 +520,9 @@ audio/mpeg. >> This enables support for Icecast versions < 2.4.0, that do not >> support the >> HTTP PUT method but the SOURCE method. >> >> +@item tls >> +Establish a TLS (HTTPS) connection to Icecast. >> + >> @end table >> >> @example >> diff --git a/libavformat/icecast.c b/libavformat/icecast.c >> index 38af16b99e..5073367fd4 100644 >> --- a/libavformat/icecast.c >> +++ b/libavformat/icecast.c >> @@ -43,6 +43,7 @@ typedef struct IcecastContext { >> int public; >> char *url; >> char *user_agent; >> + int tls; >> } IcecastContext; >> >> #define DEFAULT_ICE_USER "source" >> @@ -62,6 +63,7 @@ static const AVOption options[] = { >> { "password", "set password", OFFSET(pass), AV_OPT_TYPE_STRING, >> { .str = NULL }, 0, 0, E }, >> { "content_type", "set content-type, MUST be set if not >> audio/mpeg", OFFSET(content_type), AV_OPT_TYPE_STRING, { .str = NULL >> }, 0, 0, E }, >> { "legacy_icecast", "use legacy SOURCE method, for Icecast < >> v2.4", OFFSET(legacy_icecast), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, >> E }, >> + { "tls", "use a TLS connection", OFFSET(tls), AV_OPT_TYPE_BOOL, >> { .i64 = 0 }, 0, 1, E }, >> { NULL } >> }; >> >> @@ -161,8 +163,11 @@ static int icecast_open(URLContext *h, const >> char *uri, int flags) >> goto cleanup; >> } >> >> + // Check which underlying protocol should be used >> + const char *real_proto = (s->tls) ? "https" : "http"; > > This should give a "mixed declaration and code" compiler warning. > It does not for me, using Apple clang version 11.0.3 (clang-1103.0.32.29) I had no idea ffmpeg has this requirement still, will send a new version that separates declaration and assignment. >> + >> // Build new URI for passing to http protocol >> - ff_url_join(h_url, sizeof(h_url), "http", auth, host, port, >> "%s", path); >> + ff_url_join(h_url, sizeof(h_url), real_proto, auth, host, port, >> "%s", path); >> // Finally open http proto handler >> ret = ffurl_open_whitelist(&s->hd, h_url, AVIO_FLAG_READ_WRITE, >> NULL, >> &opt_dict, h->protocol_whitelist, >> h->protocol_blacklist, h); >> > > _______________________________________________ > ffmpeg-devel mailing list > ffmpeg-devel@ffmpeg.org > https://ffmpeg.org/mailman/listinfo/ffmpeg-devel > > To unsubscribe, visit link above, or email > ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
diff --git a/doc/protocols.texi b/doc/protocols.texi index 7aa758541c..32c829d2a3 100644 --- a/doc/protocols.texi +++ b/doc/protocols.texi @@ -520,6 +520,9 @@ audio/mpeg. This enables support for Icecast versions < 2.4.0, that do not support the HTTP PUT method but the SOURCE method. +@item tls +Establish a TLS (HTTPS) connection to Icecast. + @end table @example diff --git a/libavformat/icecast.c b/libavformat/icecast.c index 38af16b99e..5073367fd4 100644 --- a/libavformat/icecast.c +++ b/libavformat/icecast.c @@ -43,6 +43,7 @@ typedef struct IcecastContext { int public; char *url; char *user_agent; + int tls; } IcecastContext; #define DEFAULT_ICE_USER "source" @@ -62,6 +63,7 @@ static const AVOption options[] = { { "password", "set password", OFFSET(pass), AV_OPT_TYPE_STRING, { .str = NULL }, 0, 0, E }, { "content_type", "set content-type, MUST be set if not audio/mpeg", OFFSET(content_type), AV_OPT_TYPE_STRING, { .str = NULL }, 0, 0, E }, { "legacy_icecast", "use legacy SOURCE method, for Icecast < v2.4", OFFSET(legacy_icecast), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, E }, + { "tls", "use a TLS connection", OFFSET(tls), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, E }, { NULL } }; @@ -161,8 +163,11 @@ static int icecast_open(URLContext *h, const char *uri, int flags) goto cleanup; } + // Check which underlying protocol should be used + const char *real_proto = (s->tls) ? "https" : "http"; + // Build new URI for passing to http protocol - ff_url_join(h_url, sizeof(h_url), "http", auth, host, port, "%s", path); + ff_url_join(h_url, sizeof(h_url), real_proto, auth, host, port, "%s", path); // Finally open http proto handler ret = ffurl_open_whitelist(&s->hd, h_url, AVIO_FLAG_READ_WRITE, NULL, &opt_dict, h->protocol_whitelist, h->protocol_blacklist, h);