1 /*
2 * This file is part of FFmpeg.
3 *
4 * FFmpeg is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
8 *
9 * FFmpeg is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
13 *
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with FFmpeg; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18
19 #include "config.h"
20
21 #include "libavutil/avstring.h"
22 #include "libavutil/mem.h"
23
24 #include "url.h"
25
26 extern const URLProtocol ff_async_protocol;
27 extern const URLProtocol ff_bluray_protocol;
28 extern const URLProtocol ff_cache_protocol;
29 extern const URLProtocol ff_concat_protocol;
30 extern const URLProtocol ff_crypto_protocol;
31 extern const URLProtocol ff_data_protocol;
32 extern const URLProtocol ff_ffrtmpcrypt_protocol;
33 extern const URLProtocol ff_ffrtmphttp_protocol;
34 extern const URLProtocol ff_file_protocol;
35 extern const URLProtocol ff_ftp_protocol;
36 extern const URLProtocol ff_gopher_protocol;
37 extern const URLProtocol ff_gophers_protocol;
38 extern const URLProtocol ff_hls_protocol;
39 extern const URLProtocol ff_http_protocol;
40 extern const URLProtocol ff_httpproxy_protocol;
41 extern const URLProtocol ff_https_protocol;
42 extern const URLProtocol ff_icecast_protocol;
43 extern const URLProtocol ff_mmsh_protocol;
44 extern const URLProtocol ff_mmst_protocol;
45 extern const URLProtocol ff_md5_protocol;
46 extern const URLProtocol ff_pipe_protocol;
47 extern const URLProtocol ff_prompeg_protocol;
48 extern const URLProtocol ff_rtmp_protocol;
49 extern const URLProtocol ff_rtmpe_protocol;
50 extern const URLProtocol ff_rtmps_protocol;
51 extern const URLProtocol ff_rtmpt_protocol;
52 extern const URLProtocol ff_rtmpte_protocol;
53 extern const URLProtocol ff_rtmpts_protocol;
54 extern const URLProtocol ff_rtp_protocol;
55 extern const URLProtocol ff_sctp_protocol;
56 extern const URLProtocol ff_srtp_protocol;
57 extern const URLProtocol ff_subfile_protocol;
58 extern const URLProtocol ff_tee_protocol;
59 extern const URLProtocol ff_tcp_protocol;
60 extern const URLProtocol ff_tls_protocol;
61 extern const URLProtocol ff_udp_protocol;
62 extern const URLProtocol ff_udplite_protocol;
63 extern const URLProtocol ff_unix_protocol;
64 extern const URLProtocol ff_libamqp_protocol;
65 extern const URLProtocol ff_librist_protocol;
66 extern const URLProtocol ff_librtmp_protocol;
67 extern const URLProtocol ff_librtmpe_protocol;
68 extern const URLProtocol ff_librtmps_protocol;
69 extern const URLProtocol ff_librtmpt_protocol;
70 extern const URLProtocol ff_librtmpte_protocol;
71 extern const URLProtocol ff_libsrt_protocol;
72 extern const URLProtocol ff_libssh_protocol;
73 extern const URLProtocol ff_libsmbclient_protocol;
74 extern const URLProtocol ff_libzmq_protocol;
75
76 #include "libavformat/protocol_list.c"
77
78 #if FF_API_CHILD_CLASS_NEXT
ff_urlcontext_child_class_next(const AVClass * prev)79 const AVClass *ff_urlcontext_child_class_next(const AVClass *prev)
80 {
81 int i;
82
83 /* find the protocol that corresponds to prev */
84 for (i = 0; prev && url_protocols[i]; i++) {
85 if (url_protocols[i]->priv_data_class == prev) {
86 i++;
87 break;
88 }
89 }
90
91 /* find next protocol with priv options */
92 for (; url_protocols[i]; i++)
93 if (url_protocols[i]->priv_data_class)
94 return url_protocols[i]->priv_data_class;
95 return NULL;
96 }
97 #endif
98
ff_urlcontext_child_class_iterate(void ** iter)99 const AVClass *ff_urlcontext_child_class_iterate(void **iter)
100 {
101 const AVClass *ret = NULL;
102 uintptr_t i;
103
104 for (i = (uintptr_t)*iter; url_protocols[i]; i++) {
105 ret = url_protocols[i]->priv_data_class;
106 if (ret)
107 break;
108 }
109
110 *iter = (void*)(uintptr_t)(url_protocols[i] ? i + 1 : i);
111 return ret;
112 }
113
avio_enum_protocols(void ** opaque,int output)114 const char *avio_enum_protocols(void **opaque, int output)
115 {
116 const URLProtocol **p = *opaque;
117
118 p = p ? p + 1 : url_protocols;
119 *opaque = p;
120 if (!*p) {
121 *opaque = NULL;
122 return NULL;
123 }
124 if ((output && (*p)->url_write) || (!output && (*p)->url_read))
125 return (*p)->name;
126 return avio_enum_protocols(opaque, output);
127 }
128
avio_protocol_get_class(const char * name)129 const AVClass *avio_protocol_get_class(const char *name)
130 {
131 int i = 0;
132 for (i = 0; url_protocols[i]; i++) {
133 if (!strcmp(url_protocols[i]->name, name))
134 return url_protocols[i]->priv_data_class;
135 }
136 return NULL;
137 }
138
ffurl_get_protocols(const char * whitelist,const char * blacklist)139 const URLProtocol **ffurl_get_protocols(const char *whitelist,
140 const char *blacklist)
141 {
142 const URLProtocol **ret;
143 int i, ret_idx = 0;
144
145 ret = av_mallocz_array(FF_ARRAY_ELEMS(url_protocols), sizeof(*ret));
146 if (!ret)
147 return NULL;
148
149 for (i = 0; url_protocols[i]; i++) {
150 const URLProtocol *up = url_protocols[i];
151
152 if (whitelist && *whitelist && !av_match_name(up->name, whitelist))
153 continue;
154 if (blacklist && *blacklist && av_match_name(up->name, blacklist))
155 continue;
156
157 ret[ret_idx++] = up;
158 }
159
160 return ret;
161 }
162