xmet/bin/xmet-afos-ingest

65 lines
1.5 KiB
Text
Raw Normal View History

#! /usr/bin/env python3
import argparse
2025-02-22 13:53:54 -05:00
from xmet.db import Database
from xmet.afos import AFOSMessageParser
CHUNK_SIZE = 4096
def each_chunk(fh, sep: str):
buf = ''
while True:
chunk = fh.read(CHUNK_SIZE)
if chunk == '' or chunk is None:
yield buf.strip()
break
buf += chunk
while True:
try:
part, buf = buf.split(sep, 1)
except ValueError:
break
else:
yield part.strip()
parser = argparse.ArgumentParser(
description = 'Ingest National Weather Service text bulletin products'
)
parser.add_argument('--quiet', action='store_true', help='Suppress output')
parser.add_argument('--dry-run', action='store_true', help='Do not actually ingest products')
parser.add_argument('db', help='XMET SQLite3 database')
parser.add_argument('afos-text-file', help='AFOS text bulletin product file')
args = parser.parse_args()
db = Database.connect(args.db)
db.execute('begin transaction')
parser = AFOSMessageParser()
for path in getattr(args, 'afos-text-file'):
with open(path, 'r') as fh:
for data in each_chunk(fh, '\x01'):
if len(data) == 0:
continue
try:
message = parser.parse(data)
if not args.quiet:
print(f"Ingesting AFOS file {path}")
if not args.dry_run:
db.add(message)
except:
pass
db.commit()