ArchiveBox/archivebox/parsers/url_list.py

38 lines
810 B
Python
Raw Normal View History

2021-03-20 16:38:00 +00:00
__package__ = 'archivebox.parsers'
__description__ = 'URL list'
import re
2021-03-20 16:38:00 +00:00
from typing import IO, Iterable
from datetime import datetime, timezone
2021-03-20 16:38:00 +00:00
from ..index.schema import Link
from ..util import (
enforce_types,
URL_REGEX,
2021-03-20 16:38:00 +00:00
)
@enforce_types
def parse_url_list(text_file: IO[str], **_kwargs) -> Iterable[Link]:
"""Parse raw URLs from each line in a text file"""
text_file.seek(0)
for line in text_file.readlines():
url = line.strip()
if (not url) or not re.findall(URL_REGEX, url):
2021-03-20 16:38:00 +00:00
continue
yield Link(
url=url,
timestamp=str(datetime.now(timezone.utc).timestamp()),
2021-03-20 16:38:00 +00:00
title=None,
tags=None,
sources=[text_file.name],
)
KEY = 'url_list'
NAME = 'URL List'
PARSER = parse_url_list