32 int key_len,
char **dest,
int *dest_len)
34 if (!strncmp(key,
"realm=", key_len)) {
36 *dest_len =
sizeof(state->
realm);
41 int key_len,
char **dest,
int *dest_len)
45 if (!strncmp(key,
"realm=", key_len)) {
47 *dest_len =
sizeof(state->
realm);
48 }
else if (!strncmp(key,
"nonce=", key_len)) {
49 *dest = digest->
nonce;
50 *dest_len =
sizeof(digest->
nonce);
51 }
else if (!strncmp(key,
"opaque=", key_len)) {
53 *dest_len =
sizeof(digest->
opaque);
54 }
else if (!strncmp(key,
"algorithm=", key_len)) {
57 }
else if (!strncmp(key,
"qop=", key_len)) {
59 *dest_len =
sizeof(digest->
qop);
64 int key_len,
char **dest,
int *dest_len)
68 if (!strncmp(key,
"nextnonce=", key_len)) {
69 *dest = digest->
nonce;
70 *dest_len =
sizeof(digest->
nonce);
76 char *ptr = strstr(qop,
"auth");
77 char *end = ptr + strlen(
"auth");
79 if (ptr && (!*end || isspace(*end) || *end ==
',') &&
80 (ptr == qop || isspace(ptr[-1]) || ptr[-1] ==
',')) {
90 if (!strcmp(key,
"WWW-Authenticate") || !strcmp(key,
"Proxy-Authenticate")) {
108 }
else if (!strcmp(key,
"Authentication-Info")) {
119 va_start(vl, md5ctx);
121 const char* str = va_arg(vl,
const char*);
131 const char *password,
const char *uri,
136 uint32_t cnonce_buf[2];
140 char A1hash[33], A2hash[33], response[33];
141 struct AVMD5 *md5ctx;
146 snprintf(nc,
sizeof(nc),
"%08x", digest->
nc);
149 for (i = 0; i < 2; i++)
151 ff_data_to_hex(cnonce, (
const uint8_t*) cnonce_buf,
sizeof(cnonce_buf), 1);
152 cnonce[2*
sizeof(cnonce_buf)] = 0;
165 }
else if (!strcmp(digest->
algorithm,
"MD5-sess")) {
185 if (!strcmp(digest->
qop,
"auth") || !strcmp(digest->
qop,
"auth-int")) {
195 if (!strcmp(digest->
qop,
"") || !strcmp(digest->
qop,
"auth")) {
196 }
else if (!strcmp(digest->
qop,
"auth-int")) {
204 len = strlen(username) + strlen(state->
realm) + strlen(digest->
nonce) +
205 strlen(uri) + strlen(response) + strlen(digest->
algorithm) +
206 strlen(digest->
opaque) + strlen(digest->
qop) + strlen(cnonce) +
212 snprintf(authstr, len,
"Authorization: Digest ");
215 av_strlcatf(authstr, len,
"username=\"%s\"", username);
219 av_strlcatf(authstr, len,
",response=\"%s\"", response);
224 if (digest->
qop[0]) {
226 av_strlcatf(authstr, len,
",cnonce=\"%s\"", cnonce);
236 const char *path,
const char *method)
238 char *authstr =
NULL;
240 if (!auth || !strchr(auth,
':'))
245 int len = auth_b64_len + 30;
250 snprintf(authstr, len,
"Authorization: Basic ");
251 ptr = authstr + strlen(authstr);
253 av_strlcat(ptr,
"\r\n", len - (ptr - authstr));
255 char *username =
av_strdup(auth), *password;
260 if ((password = strchr(username,
':'))) {