Reporting a bug or vulnerability¶
If you have identified that Cahute or any of its utilities does not work properly, this guide is here to help you identify the steps in reporting the issue properly for it to be fixed, or in some cases, at least publicly documented.
Writing a bug or vulnerability report¶
The report MUST include the following information:
System and system version on which the issue occurs; e.g. Debian 14, Ubuntu 22.04 LTS, Windows 11 Pro, …
Hardware architecture on which the issue occurs; e.g. x64, ARM, …
Cahute version (e.g. 0.1, 1.2, …).
If the issue regards a communication protocol, the following information must also be included:
The calculator model and OS version, e.g. Graph 90+E with OS 03.60.2202.
The cable type, brand and/or model, e.g.:
E119932-U USB cable (already implicated in at least #31);
SB-88 or SB-88(A) USB serial cable;
…
Whether you have tested with other calculators of the same kind or not.
Whether you have tested with other cables of the same kind but not the same brand, e.g. third-party USB cables.
Note
In order to identify a USB cable, you can read the text on the cable itself and transcribe it in your report.
Then, you must indicate the steps to reproduce the issue, on both the host and any device that was implicated in the operation. It is important that you respect the exact order in which you execute every action, since this may be the source of the issue.
Note
An example of concrete steps to reproduce an issue would be the following:
Graph 35+USB is already connected to the PC over E119932-U USB cable.
Go to LINK, select “Capt” (F6), then “Projector” (F3).
Run
p7screen -l info
.Command emits the following logs, then exits:
[2024-08-08 21:09:26 cahute warning] open_simple_usb_link: Calculator not found, retrying in 1 second.
[2024-08-08 21:09:27 cahute warning] open_simple_usb_link: Calculator not found, retrying in 1 second.
[2024-08-08 21:09:28 cahute warning] open_simple_usb_link: Calculator not found, retrying in 1 second.
[2024-08-08 21:09:29 cahute warning] open_simple_usb_link: Calculator not found, retrying in 1 second.
Could not connect to the calculator.
- Is it plugged in and in PROJ mode?
- Have you tried unplugging, plugging and selecting Projector on pop-up?
- Have you tried changing the cable?
In this precise example, it is a mistake by the user: the Projector mode must be selected when the USB cable is plugged in, and not at a later stage.
Warning
If the issue involves a command-line utility, it is recommended to enable
maximum verbosity, e.g. using p7 -l info ...
, p7screen -l info ...
,
CaS ... -d
, and so on, and to include the raw output including the
logs.
A template in markdown for writing a bug report is the following:
- System and version:
- Architecture:
- Cahute version:
- Calculator and version *(if applicable)*:
- Communication cable *(if applicable)*:
Steps to reproduce the issue (with maximum verbosity options added to the
command, such as ``--log info``):
- ...
Sending your bug or vulnerability report¶
If your issue has security implications, e.g. if it allows a malicious device to access the host and/or execute arbitrary code without authorisation, please send an e-mail to Thomas Touhey, the maintainer of Cahute, at <security@cahuteproject.org>.
Note
Please only use this e-mail address if there is security implications to your demand. If you are not sure if your issue qualifies or not, send it anyway; use your best judgment.
For all other issues, you can create an issue on the issue tracker at Gitlab.
Warning
Once your issue is up or sent, please check on it every few days at least, or leave a way for the maintainers to contact you without giving up their privacy (i.e. no phone numbers, social network profile or instant messaging address); an e-mail address is fine.
An issue reported by someone who can’t answer once additional details are required from them is an issue that gets closed and has wasted everyone’s time and efforts.
Warning
For any type of issue, due to the fact that Cahute is free software maintained by people on their free time, there is no guarantee of any delay, or even of a response or that the issue won’t be closed due to lack of availability on the maintainers’ part.
Note however that this warning is worst case scenario, and hopefully, it won’t come to that for any correctly reported issue.