mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2025-01-10 18:09:31 +00:00
5aa1a378ef
I'm a bit dumb and forgot to add code that frees journal.Reader instances from memory. Co-authored-by: nhnn <nhnn@disroot.org> Co-authored-by: Inex Code <inex.code@selfprivacy.org> Reviewed-on: https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api/pulls/158 Reviewed-by: Inex Code <inex.code@selfprivacy.org> Co-authored-by: nhnn <nhnn@noreply.git.selfprivacy.org> Co-committed-by: nhnn <nhnn@noreply.git.selfprivacy.org>
38 lines
932 B
Python
38 lines
932 B
Python
from typing import AsyncGenerator
|
|
from systemd import journal
|
|
import asyncio
|
|
|
|
from selfprivacy_api.graphql.queries.logs import LogEntry
|
|
|
|
|
|
async def log_stream() -> AsyncGenerator[LogEntry, None]:
|
|
j = journal.Reader()
|
|
|
|
j.seek_tail()
|
|
j.get_previous()
|
|
|
|
queue = asyncio.Queue()
|
|
|
|
async def callback():
|
|
if j.process() != journal.APPEND:
|
|
return
|
|
for entry in j:
|
|
await queue.put(entry)
|
|
|
|
asyncio.get_event_loop().add_reader(j, lambda: asyncio.ensure_future(callback()))
|
|
|
|
try:
|
|
while True:
|
|
entry = await queue.get()
|
|
try:
|
|
yield LogEntry(entry)
|
|
except Exception:
|
|
asyncio.get_event_loop().remove_reader(j)
|
|
j.close()
|
|
return
|
|
queue.task_done()
|
|
except asyncio.CancelledError:
|
|
asyncio.get_event_loop().remove_reader(j)
|
|
j.close()
|
|
return
|