Python module for Accounting
Erdal Emlik
erdalemlik at icloud.com
Thu Feb 13 09:08:18 UTC 2025
Hi List,
I’m trying to send accounting logs to Kafka using the FreeRADIUS Python module (example.py). I’ve implemented a callback and exception handling, but when I manually stop the Kafka service, I can’t catch any errors—neither in the callback nor in the exception block.
def delivery_report(err,msg):
if err is not None:
logstash_logger.add_info_log(f"Failed Message, Key : {msg.key()} Value : {msg.value()} Err : {err}")
def accounting(p):
try:
record = create_record(p)
logstash_logger.add_info_log("accounting started 1")
if len(record.User_Name) == 0:
raise Exception("User-Name can not be found in request!")
key_for_record = create_key_for_record(record)
logstash_logger.add_info_log("accounting started 2")
kafka_producer.produce(kafka_topic, key=key_for_record, value=json.dumps(record.__dict__),callback=delivery_report)
kafka_producer.poll(0)
logstash_logger.add_info_log("accounting started 3")
except KafkaException as e:
logstash_logger.add_info_log(f"accounting started 4 {err}")
logstash_logger.add_info_log("accounting started 5")
return radiusd.RLM_MODULE_OK
I can see logs 1-2-3-5, but my goal is to detect when a message fails to send and store it for later retries. However, I’m not sure if I’m on the right path.
If needed, I can provide more details, debug output, and code snippets.
Looking forward to your guidance.
Best regards,
More information about the Freeradius-Users
mailing list