1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

[ecmascript] Read also ~/.elinks/disallowed.txt

Lines in disallowed.txt may contain prefixes of bad sites.
If current url matches any of line with disallowed prefixes,
ecmascript is not executed.
If disallowed.txt is empty or not matched, then
if allow.txt is not empty, and some prefix from this file
matches current url, ecmascript is allowed.
If allow.txt is empty, ecmascript is allowed too,
otherwise ecmascript is disabled on given page.
This commit is contained in:
Witold Filipczyk 2021-05-07 11:29:33 +02:00
parent 7ba9caf227
commit 004a778382
2 changed files with 40 additions and 11 deletions

View File

@ -74,6 +74,7 @@ static union option_info ecmascript_options[] = {
static int interpreter_count; static int interpreter_count;
static INIT_LIST_OF(struct string_list_item, allowed_urls); static INIT_LIST_OF(struct string_list_item, allowed_urls);
static INIT_LIST_OF(struct string_list_item, disallowed_urls);
char *console_log_filename; char *console_log_filename;
@ -100,9 +101,7 @@ read_url_list(void)
filename = straconcat(elinks_home, STRING_DIR_SEP, ALLOWED_ECMASCRIPT_URL_PREFIXES, NULL); filename = straconcat(elinks_home, STRING_DIR_SEP, ALLOWED_ECMASCRIPT_URL_PREFIXES, NULL);
if (!filename) { if (filename) {
return;
}
f = fopen(filename, "r"); f = fopen(filename, "r");
@ -113,6 +112,22 @@ read_url_list(void)
fclose(f); fclose(f);
} }
mem_free(filename); mem_free(filename);
}
filename = straconcat(elinks_home, STRING_DIR_SEP, DISALLOWED_ECMASCRIPT_URL_PREFIXES, NULL);
if (filename) {
f = fopen(filename, "r");
if (f) {
while (fgets(line, 4096, f)) {
add_to_string_list(&disallowed_urls, line, strlen(line) - 1);
}
fclose(f);
}
mem_free(filename);
}
} }
int int
@ -127,7 +142,7 @@ get_ecmascript_enable(struct ecmascript_interpreter *interpreter)
return 0; return 0;
} }
if (list_empty(allowed_urls)) { if (list_empty(allowed_urls) && list_empty(disallowed_urls)) {
return 1; return 1;
} }
@ -136,6 +151,19 @@ get_ecmascript_enable(struct ecmascript_interpreter *interpreter)
return 0; return 0;
} }
foreach(item, disallowed_urls) {
struct string *string = &item->string;
if (string->length <= 0) {
continue;
}
if (!is_prefix(string->source, url, string->length)) {
mem_free(url);
move_to_top_of_list(disallowed_urls, item);
return 0;
}
}
foreach(item, allowed_urls) { foreach(item, allowed_urls) {
struct string *string = &item->string; struct string *string = &item->string;
@ -150,7 +178,7 @@ get_ecmascript_enable(struct ecmascript_interpreter *interpreter)
} }
mem_free(url); mem_free(url);
return 0; return list_empty(allowed_urls);
} }

View File

@ -25,6 +25,7 @@
#define ELINKS_TEMPNAME_PREFIX "elinks" #define ELINKS_TEMPNAME_PREFIX "elinks"
#define ALLOWED_ECMASCRIPT_URL_PREFIXES "allow.txt" #define ALLOWED_ECMASCRIPT_URL_PREFIXES "allow.txt"
#define DISALLOWED_ECMASCRIPT_URL_PREFIXES "disallow.txt"
#define DNS_CACHE_TIMEOUT 3600 /* in seconds */ #define DNS_CACHE_TIMEOUT 3600 /* in seconds */