diff options
| author | Yuchen Pei <id@ypei.org> | 2023-10-27 23:38:11 +1100 | 
|---|---|---|
| committer | Yuchen Pei <id@ypei.org> | 2023-10-27 23:38:11 +1100 | 
| commit | 8ee5aba1bd932f248297f8de3eb7bbcdae601bb4 (patch) | |
| tree | efb5c4cccf0fa689c00559adc719b711092d02b2 /native-apps | |
| parent | 8926cb68f45ab3dc0bd7bc7eed2cd40c4cc437cd (diff) | |
[PoC] Log LibreJS reportsnative-messaging-app
- run ./build.sh
- install the built librejs.xpi as a temporary extension[1]
- check the librejs version is 7.21.2
- load some sites e.g. <https://fsf.org>, <https://archive.org>, and
  the reports should be logged into /tmp/librejs.log
[1] https://extensionworkshop.com/documentation/develop/temporary-installation-in-firefox/
Diffstat (limited to 'native-apps')
| -rwxr-xr-x | native-apps/librejs-logger.py | 53 | ||||
| -rw-r--r-- | native-apps/librejs.json | 7 | 
2 files changed, 60 insertions, 0 deletions
| diff --git a/native-apps/librejs-logger.py b/native-apps/librejs-logger.py new file mode 100755 index 0000000..be79409 --- /dev/null +++ b/native-apps/librejs-logger.py @@ -0,0 +1,53 @@ +#!/usr/bin/env -S python3 -u + +# Note that running python with the `-u` flag is required on Windows, +# in order to ensure that stdin and stdout are opened in binary, rather +# than text, mode. + +import sys +import json +import struct +import subprocess +import os +import logging + +# Read a message from stdin and decode it. +def getMessage(): +    rawLength = sys.stdin.buffer.read(4) +    if len(rawLength) == 0: +        sys.exit(0) +    messageLength = struct.unpack('@I', rawLength)[0] +    message = sys.stdin.buffer.read(messageLength).decode('utf-8') +    return json.loads(message) + +# Encode a message for transmission, +# given its content. +def encodeMessage(messageContent): +    # https://docs.python.org/3/library/json.html#basic-usage +    # To get the most compact JSON representation, you should specify +    # (',', ':') to eliminate whitespace. +    # We want the most compact representation because the browser rejects # messages that exceed 1 MB. +    encodedContent = json.dumps(messageContent, separators=(',', ':')).encode('utf-8') +    encodedLength = struct.pack('@I', len(encodedContent)) +    return {'length': encodedLength, 'content': encodedContent} + +# Send an encoded message to stdout +def sendMessage(encodedMessage): +    sys.stdout.buffer.write(encodedMessage['length']) +    sys.stdout.buffer.write(encodedMessage['content']) +    sys.stdout.buffer.flush() + + +counter = 0 +logging.basicConfig(filename="/tmp/librejs.log", +                    filemode='a', +                    format='%(asctime)s.%(msecs)d %(name)s %(levelname)s %(message)s', +                    datefmt='%H:%M:%S', +                    level=logging.DEBUG) + +while True: +    receivedMessage = getMessage() +    devnull = open(os.devnull, 'w') +    counter += 1 +    logging.info(f'[{counter}] {receivedMessage}') +    sendMessage(encodeMessage(f'Logged message No. {counter}')) diff --git a/native-apps/librejs.json b/native-apps/librejs.json new file mode 100644 index 0000000..b927b76 --- /dev/null +++ b/native-apps/librejs.json @@ -0,0 +1,7 @@ +{ +  "name": "librejs", +  "description": "Logging LibreJS reports", +  "path": "/tmp/librejs-logger.py", +  "type": "stdio", +  "allowed_extensions": ["jid1-KtlZuoiikVfFew@jetpack"] +} | 
