2003-12-08 14:25:35 +01:00
|
|
|
/*
|
|
|
|
* HTTP Cookies
|
|
|
|
* Reads Netscape and Mozilla cookies.txt files
|
|
|
|
*
|
2010-01-30 23:26:47 +01:00
|
|
|
* Copyright (c) 2003 Dave Lambley <mplayer@davel.me.uk>
|
|
|
|
*
|
2015-04-13 09:36:54 +02:00
|
|
|
* This file is part of mpv.
|
2010-01-30 23:26:47 +01:00
|
|
|
*
|
2015-04-13 09:36:54 +02:00
|
|
|
* mpv is free software; you can redistribute it and/or modify
|
2010-01-30 23:26:47 +01:00
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
2015-04-13 09:36:54 +02:00
|
|
|
* mpv is distributed in the hope that it will be useful,
|
2010-01-30 23:26:47 +01:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
2015-04-13 09:36:54 +02:00
|
|
|
* with mpv. If not, see <http://www.gnu.org/licenses/>.
|
2003-12-08 14:25:35 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <dirent.h>
|
2006-06-05 00:41:27 +02:00
|
|
|
#include <inttypes.h>
|
2006-09-07 02:10:44 +02:00
|
|
|
#include <limits.h>
|
2003-12-08 14:25:35 +01:00
|
|
|
|
2012-02-03 08:05:11 +01:00
|
|
|
#include "osdep/io.h"
|
|
|
|
|
2013-12-17 02:02:25 +01:00
|
|
|
#include "options/options.h"
|
2003-12-08 14:25:35 +01:00
|
|
|
#include "cookies.h"
|
2013-12-17 02:39:45 +01:00
|
|
|
#include "common/msg.h"
|
2003-12-08 14:25:35 +01:00
|
|
|
|
|
|
|
#define MAX_COOKIES 20
|
|
|
|
|
|
|
|
typedef struct cookie_list_type {
|
|
|
|
char *name;
|
|
|
|
char *value;
|
|
|
|
char *domain;
|
|
|
|
char *path;
|
|
|
|
|
|
|
|
int secure;
|
|
|
|
|
|
|
|
struct cookie_list_type *next;
|
|
|
|
} cookie_list_t;
|
|
|
|
|
|
|
|
/* Like strdup, but stops at anything <31. */
|
2013-12-22 13:28:55 +01:00
|
|
|
static char *col_dup(void *talloc_ctx, const char *src)
|
2003-12-08 14:25:35 +01:00
|
|
|
{
|
|
|
|
int length = 0;
|
|
|
|
while (src[length] > 31)
|
2014-04-13 18:00:51 +02:00
|
|
|
length++;
|
2003-12-08 14:25:35 +01:00
|
|
|
|
2013-12-22 13:28:55 +01:00
|
|
|
return talloc_strndup(talloc_ctx, src, length);
|
2003-12-08 14:25:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Finds the start of all the columns */
|
2014-01-19 11:53:03 +01:00
|
|
|
static int parse_line(char **ptr, char *cols[7])
|
2003-12-08 14:25:35 +01:00
|
|
|
{
|
|
|
|
int col;
|
|
|
|
cols[0] = *ptr;
|
|
|
|
|
|
|
|
for (col = 1; col < 7; col++) {
|
2014-04-13 18:00:51 +02:00
|
|
|
for (; (**ptr) > 31; (*ptr)++);
|
|
|
|
if (**ptr == 0)
|
|
|
|
return 0;
|
|
|
|
(*ptr)++;
|
|
|
|
if ((*ptr)[-1] != 9)
|
|
|
|
return 0;
|
|
|
|
cols[col] = (*ptr);
|
2003-12-08 14:25:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Loads a file into RAM */
|
2013-12-21 20:36:45 +01:00
|
|
|
static char *load_file(struct mp_log *log, const char *filename, int64_t * length)
|
2003-12-08 14:25:35 +01:00
|
|
|
{
|
2013-05-06 20:58:54 +02:00
|
|
|
int fd;
|
2012-10-30 18:28:34 +01:00
|
|
|
char *buffer = NULL;
|
2003-12-08 14:25:35 +01:00
|
|
|
|
2013-12-21 20:36:45 +01:00
|
|
|
mp_verbose(log, "Loading cookie file: %s\n", filename);
|
2003-12-08 14:25:35 +01:00
|
|
|
|
2013-11-30 22:40:51 +01:00
|
|
|
fd = open(filename, O_RDONLY | O_CLOEXEC);
|
2003-12-08 14:25:35 +01:00
|
|
|
if (fd < 0) {
|
2014-04-13 18:00:51 +02:00
|
|
|
mp_verbose(log, "Could not open");
|
|
|
|
goto err_out;
|
2003-12-08 14:25:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
*length = lseek(fd, 0, SEEK_END);
|
|
|
|
|
|
|
|
if (*length < 0) {
|
2014-04-13 18:00:51 +02:00
|
|
|
mp_verbose(log, "Could not find EOF");
|
|
|
|
goto err_out;
|
2003-12-08 14:25:35 +01:00
|
|
|
}
|
|
|
|
|
2006-06-05 00:41:27 +02:00
|
|
|
if (*length > SIZE_MAX - 1) {
|
2014-04-13 18:00:51 +02:00
|
|
|
mp_verbose(log, "File too big, could not malloc.");
|
|
|
|
goto err_out;
|
2006-06-05 00:41:27 +02:00
|
|
|
}
|
|
|
|
|
2010-02-03 18:50:18 +01:00
|
|
|
lseek(fd, 0, SEEK_SET);
|
2003-12-08 14:25:35 +01:00
|
|
|
|
|
|
|
if (!(buffer = malloc(*length + 1))) {
|
2014-04-13 18:00:51 +02:00
|
|
|
mp_verbose(log, "Could not malloc.");
|
|
|
|
goto err_out;
|
2003-12-08 14:25:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (read(fd, buffer, *length) != *length) {
|
2014-04-13 18:00:51 +02:00
|
|
|
mp_verbose(log, "Read is behaving funny.");
|
|
|
|
goto err_out;
|
2003-12-08 14:25:35 +01:00
|
|
|
}
|
|
|
|
close(fd);
|
|
|
|
buffer[*length] = 0;
|
|
|
|
|
|
|
|
return buffer;
|
2012-10-30 18:28:34 +01:00
|
|
|
|
|
|
|
err_out:
|
|
|
|
if (fd != -1) close(fd);
|
|
|
|
free(buffer);
|
|
|
|
return NULL;
|
2003-12-08 14:25:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Loads a cookies.txt file into a linked list. */
|
2013-12-22 13:28:55 +01:00
|
|
|
static struct cookie_list_type *load_cookies_from(void *ctx,
|
|
|
|
struct mp_log *log,
|
|
|
|
const char *filename)
|
2003-12-08 14:25:35 +01:00
|
|
|
{
|
2013-01-24 14:32:35 +01:00
|
|
|
char *ptr, *file;
|
2012-11-18 20:46:12 +01:00
|
|
|
int64_t length;
|
2003-12-08 14:25:35 +01:00
|
|
|
|
2013-12-21 20:36:45 +01:00
|
|
|
ptr = file = load_file(log, filename, &length);
|
2003-12-08 14:25:35 +01:00
|
|
|
if (!ptr)
|
2014-04-13 18:00:51 +02:00
|
|
|
return NULL;
|
2003-12-08 14:25:35 +01:00
|
|
|
|
2013-12-22 13:28:55 +01:00
|
|
|
struct cookie_list_type *list = NULL;
|
2012-10-30 18:28:34 +01:00
|
|
|
while (*ptr) {
|
2014-04-13 18:00:51 +02:00
|
|
|
char *cols[7];
|
|
|
|
if (parse_line(&ptr, cols)) {
|
|
|
|
struct cookie_list_type *new;
|
|
|
|
new = talloc_zero(ctx, cookie_list_t);
|
|
|
|
new->name = col_dup(new, cols[5]);
|
|
|
|
new->value = col_dup(new, cols[6]);
|
|
|
|
new->path = col_dup(new, cols[2]);
|
|
|
|
new->domain = col_dup(new, cols[0]);
|
|
|
|
new->secure = (*(cols[3]) == 't') || (*(cols[3]) == 'T');
|
|
|
|
new->next = list;
|
|
|
|
list = new;
|
|
|
|
}
|
2003-12-08 14:25:35 +01:00
|
|
|
}
|
2013-01-24 14:32:35 +01:00
|
|
|
free(file);
|
2003-12-08 14:25:35 +01:00
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
2013-01-24 16:05:52 +01:00
|
|
|
// Return a cookies string as expected by lavf (libavformat/http.c). The format
|
|
|
|
// is like a Set-Cookie header (http://curl.haxx.se/rfc/cookie_spec.html),
|
|
|
|
// separated by newlines.
|
2013-12-22 13:11:22 +01:00
|
|
|
char *cookies_lavf(void *talloc_ctx, struct mp_log *log, char *file)
|
2013-01-24 16:05:52 +01:00
|
|
|
{
|
2013-12-22 13:28:55 +01:00
|
|
|
void *tmp = talloc_new(NULL);
|
|
|
|
struct cookie_list_type *list = NULL;
|
|
|
|
if (file && file[0])
|
|
|
|
list = load_cookies_from(tmp, log, file);
|
2013-01-24 16:05:52 +01:00
|
|
|
|
2013-12-22 13:11:22 +01:00
|
|
|
char *res = talloc_strdup(talloc_ctx, "");
|
2013-01-24 16:05:52 +01:00
|
|
|
|
|
|
|
while (list) {
|
|
|
|
res = talloc_asprintf_append_buffer(res,
|
|
|
|
"%s=%s; path=%s; domain=%s; %s\n", list->name, list->value,
|
|
|
|
list->path, list->domain, list->secure ? "secure" : "");
|
|
|
|
list = list->next;
|
|
|
|
}
|
|
|
|
|
2013-12-22 13:28:55 +01:00
|
|
|
talloc_free(tmp);
|
2013-01-24 16:05:52 +01:00
|
|
|
return res;
|
|
|
|
}
|