__package__ = 'archivebox.parsers' __description__ = 'Plain Text' from typing import IO, Iterable from datetime import datetime, timezone from ..index.schema import Link from archivebox.misc.util import ( htmldecode, enforce_types, find_all_urls, ) @enforce_types def parse_generic_txt_export(text_file: IO[str], **_kwargs) -> Iterable[Link]: """Parse links from a text file, ignoring other text""" text_file.seek(0) for line in text_file.readlines(): if not line.strip(): continue # # if the line is a local file path that resolves, then we can archive it # if line.startswith('file://'): # try: # if Path(line).exists(): # yield Link( # url=line, # timestamp=str(datetime.now(timezone.utc).timestamp()), # title=None, # tags=None, # sources=[text_file.name], # ) # except (OSError, PermissionError): # # nvm, not a valid path... # pass # otherwise look for anything that looks like a URL in the line for url in find_all_urls(line): yield Link( url=htmldecode(url), timestamp=str(datetime.now(timezone.utc).timestamp()), title=None, tags=None, sources=[text_file.name], ) KEY = 'txt' NAME = 'Generic TXT' PARSER = parse_generic_txt_export