-
Notifications
You must be signed in to change notification settings - Fork 1.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update rf_bridge.rst #4541
base: current
Are you sure you want to change the base?
Update rf_bridge.rst #4541
Conversation
Added references to mightymos firmware
WalkthroughThe pull request focuses on updating the documentation for the RF Bridge Component in the Changes
Possibly related PRs
Suggested reviewers
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (3)
components/rf_bridge.rst (3)
1-1
: LGTM! Clear and informative introduction.The updated introduction provides excellent technical details about the different RF Bridge versions and their microcontrollers. The information is accurate and helpful for users.
Consider adding a line break between the title and the SEO block for better readability in the source.
Also applies to: 9-11
50-51
: Clarify which ID belongs to which component.While both ID descriptions are present, it's not immediately clear which one refers to the UART configuration and which to the RF bridge configuration. Consider updating the descriptions to:
- - **id** (*Optional*, :ref:`config-id`): Manually specify the ID of the UART hub. - - **id** (*Optional*, :ref:`config-id`): Manually specify the ID of the RF bridge. Used for code generation and event tracking in home assistant. + - **uart_id** (*Optional*, :ref:`config-id`): Manually specify the ID of the UART hub in the uart configuration block. + - **id** (*Optional*, :ref:`config-id`): Manually specify the ID of the RF bridge component. Used for code generation and event tracking in home assistant.
Line range hint
362-425
: LGTM with minor formatting suggestions.The Home Assistant integration example is comprehensive and well-structured. However, there are some minor formatting inconsistencies to address:
- ## send standard RF using intiger values + ## Send standard RF using integer valuesAlso, consider consistent indentation in the YAML configuration to improve readability.
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
components/rf_bridge.rst
(13 hunks)
🧰 Additional context used
📓 Path-based instructions (1)
components/rf_bridge.rst (1)
Pattern **
: - Do not generate or add any sequence diagrams
🔇 Additional comments (5)
components/rf_bridge.rst (5)
31-37
: LGTM! Well-structured configuration example.
The configuration example clearly demonstrates the proper usage of IDs for both UART and RF bridge components.
Line range hint 111-137
: LGTM! Clear documentation of the beep functionality.
The beep action documentation is well-structured with clear examples in both YAML and C++.
167-198
: LGTM! Comprehensive documentation of the send_raw action.
The documentation clearly explains the raw command functionality, including the firmware requirements and limitations. Both YAML and C++ examples are well-presented.
205-209
: LGTM! Clear explanation of firmware options.
The section effectively explains the advanced capabilities available with alternative firmware options, providing links to both Portisch and Mightymos firmware repositories.
449-449
: LGTM! Appropriate addition to references.
The Mightymos firmware link is a valuable addition to the references section.
✅ Deploy Preview for esphome ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (4)
components/rf_bridge.rst (4)
9-11
: Fix typos in the introductionThere are a few typographical errors in the introduction:
- Line 9: "singals" should be "signals"
- Line 11: "embeded" should be "embedded"
167-198
: Consider adding raw command format specificationWhile the documentation clearly explains the functionality, it would be helpful to add a note explaining the expected format of the raw command string (e.g., hexadecimal format, length requirements, etc.).
326-326
: Remove duplicate converter linkThe line contains duplicate links to the same converter tool.
- For this, you can use the tool `BitBucket Converter <https://bbconv.hrbl.pl/>`__ or `B1 Converter <https://bbconv.hrbl.pl/>`__ + For this, you can use the `B1 Converter <https://bbconv.hrbl.pl/>`__ tool
Line range hint
362-393
: Fix typo and improve formatting in configuration example
- Fix typo in comment:
- Line 372: "intiger" should be "integer"
- Consider improving readability with consistent indentation in the configuration example.
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
components/rf_bridge.rst
(13 hunks)
🧰 Additional context used
📓 Path-based instructions (1)
components/rf_bridge.rst (1)
Pattern **
: - Do not generate or add any sequence diagrams
🔇 Additional comments (4)
components/rf_bridge.rst (4)
31-37
: LGTM! Clear UART and RF bridge configuration
The UART and RF bridge configuration is well-structured with appropriate IDs and pin assignments matching the hardware specifications.
Line range hint 111-137
: LGTM! Well-documented beep functionality
The beep action documentation is clear, complete, and includes both YAML and lambda examples with proper parameter explanation.
205-209
: LGTM! Clear firmware capabilities documentation
The section effectively explains the differences between firmware options and their capabilities, with proper references to both Portisch and Mightymos firmware.
Line range hint 399-425
: LGTM! Comprehensive event data configuration
The event data configuration is well-documented with both hex and integer format options, and clearly separates standard and advanced firmware capabilities.
Typos fix
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Nitpick comments (4)
components/rf_bridge.rst (4)
34-40
: Add clarifying comments to the configuration example.While the configuration is correct, adding comments would help users understand the purpose of each ID.
uart: - id: uart_hub + id: uart_hub # ID for referencing the UART bus in other components baud_rate: 19200 tx_pin: 1 rx_pin: 3 rf_bridge: - id: kitchen_RF_bridge + id: kitchen_RF_bridge # ID for referencing this specific RF bridge instance
Line range hint
114-140
: Add firmware compatibility note.Consider adding a note to explicitly state that this functionality works with all firmware versions (OEM, Portisch, and Mightymos).
``rf_bridge.beep`` Action -------------------------- Activate the internal buzzer to make a beep. + +.. note:: + + This functionality is available with all firmware versions (OEM, Portisch, and Mightymos).
171-203
: Add warning about raw command length limitations.Consider adding a warning about potential length limitations of raw commands in different firmware versions.
Send a raw command to the onboard radio chip. The OEM RF firmware is able to send raw only for standard signals (usually short), for other signals (B0 transmit), Portisch or Mightymos fimrware is needed. +.. warning:: + + Raw command length limitations vary by firmware: + - OEM firmware: Limited to standard (short) signals + - Portisch/Mightymos firmware: Supports longer raw commands for advanced protocols
356-367
: Add context for radio reset functionality.Consider adding information about when users might need to reset the radio controller.
Reset radio *********** +This functionality allows you to reset the radio controller if it becomes unresponsive or stops receiving/transmitting correctly. + For *Portisch* or *Mightymos* firmware
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
components/rf_bridge.rst
(15 hunks)
🧰 Additional context used
📓 Path-based instructions (1)
components/rf_bridge.rst (1)
Pattern **
: - Do not generate or add any sequence diagrams
🔇 Additional comments (3)
components/rf_bridge.rst (3)
9-14
: LGTM! Clear and informative introduction.
The introduction effectively distinguishes between different RF Bridge versions and their respective microcontrollers.
210-214
: LGTM! Clear explanation of firmware options.
The section effectively explains the benefits of alternative firmware and provides appropriate links to both Portisch and Mightymos projects.
Line range hint 378-514
: LGTM! Comprehensive configuration examples.
The examples effectively demonstrate various use cases and integration with Home Assistant. The inclusion of both basic and advanced functionality helps users understand the component's capabilities.
components/rf_bridge.rst
Outdated
@@ -284,7 +328,7 @@ The raw data will be available in the log and can later be used with :ref:`rf_br | |||
.. note:: | |||
|
|||
A conversion from *B1* (received) raw format to *B0* (send) raw command format should be applied. | |||
For this, you can use the tool `BitBucket Converter <https://bbconv.hrbl.pl/>`__ | |||
For this, you can use the tool `BitBucket Converter <https://bbconv.hrbl.pl/>`__ or `B1 Converter <https://bbconv.hrbl.pl/>`__ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Remove duplicate converter link.
The line contains two identical links to the B1 converter.
- For this, you can use the tool `BitBucket Converter <https://bbconv.hrbl.pl/>`__ or `B1 Converter <https://bbconv.hrbl.pl/>`__
+ For this, you can use the `B1 Converter <https://bbconv.hrbl.pl/>`__
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
For this, you can use the tool `BitBucket Converter <https://bbconv.hrbl.pl/>`__ or `B1 Converter <https://bbconv.hrbl.pl/>`__ | |
For this, you can use the `B1 Converter <https://bbconv.hrbl.pl/>`__ |
Removed duplicate link
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (3)
components/rf_bridge.rst (3)
34-37
: Add clarification about UART ID usage.While the UART configuration is correct, it would be helpful to explicitly mention that the
uart_hub
ID is used to link the UART bus to the RF bridge component.uart: id: uart_hub baud_rate: 19200 tx_pin: 1 rx_pin: 3 + # The uart_hub ID is used to connect the RF bridge to this UART bus rf_bridge: + uart_id: uart_hub
176-181
: Add warning about OEM firmware limitations.While the distinction between OEM and alternative firmware capabilities is mentioned, it would be helpful to add a clear warning about OEM firmware limitations.
Send a raw command to the onboard radio chip. The OEM RF firmware is able to send raw only for standard signals (usually short), for other signals (B0 transmit), Portisch or Mightymos fimrware is needed. +.. warning:: + + The OEM firmware has limited capabilities for raw transmissions. Complex or long signals may not work correctly without alternative firmware. This can be used to send raw RF codes in automations, mainly for protocols that are not supported.
425-431
: Fix YAML indentation.The event configuration block has incorrect indentation which could cause confusion.
- - homeassistant.event: - event: esphome.rf_code_received - data: - sync: !lambda 'return int(data.sync);' - low: !lambda 'return int(data.low);' - high: !lambda 'return int(data.high);' - code: !lambda 'return int(data.code);' + - homeassistant.event: + event: esphome.rf_code_received + data: + sync: !lambda 'return int(data.sync);' + low: !lambda 'return int(data.low);' + high: !lambda 'return int(data.high);' + code: !lambda 'return int(data.code);'
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
components/rf_bridge.rst
(15 hunks)
🧰 Additional context used
📓 Path-based instructions (1)
components/rf_bridge.rst (1)
Pattern **
: - Do not generate or add any sequence diagrams
🔇 Additional comments (4)
components/rf_bridge.rst (4)
9-14
: LGTM! Clear and informative introduction.
The introduction effectively describes the hardware variants and their components, making it easier for users to identify their device type.
Line range hint 114-140
: LGTM! Well-structured beep action documentation.
The beep action is correctly documented as a core feature, independent of the Portisch firmware. The examples and configuration options are clear and complete.
331-331
: Remove duplicate converter link.
The line contains two similar links to B1 converters. Consider keeping only one or clarifying the difference between them.
- For this, you can use the tool `BitBucket Converter <https://bbconv.hrbl.pl/>`__ or `B1 Converter <https://jonajona.nl/convertB1.html/>`__
+ For this, you can use the `B1 Converter <https://jonajona.nl/convertB1.html/>`__
464-513
: LGTM! Comprehensive and practical examples.
The additional examples effectively demonstrate various use cases including buttons for different modes and a practical LED strip control example. This will be very helpful for users implementing their own solutions.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Removed uart_id
and put id
twice in the example?
Hi thanks for the review. Yes UART_id is not a valid syntax in esphome, there's a |
You can't have in the documentation, in the same section two |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Nitpick comments (4)
components/rf_bridge.rst (4)
9-14
: Enhance readability with bullet points formatting.The hardware variants description would be more readable with consistent bullet point formatting.
-The ``RF Bridge`` Component provides the ability to send and receive 433MHz signals (like RF remotes/key fobs) using radio microcontrollers founds on RF bridge devices ( eg. Sonoff RF bridge). - -* The black Sonoff RF Bridge (R1, R2 V1.0) has an ESP8266 (for WIFI/ESPHome) and an embedded EFM8BB1 microcontroller (433 MHz). -* The white Sonoff RF Bridge (R2 V2.0) has ESP8266 and an embedded OB38S003 microcontroller (433 MHz). +The ``RF Bridge`` Component provides the ability to send and receive 433MHz signals (like RF remotes/key fobs) using radio microcontrollers found on RF bridge devices (e.g., Sonoff RF bridge). + +Available hardware variants: +* The black Sonoff RF Bridge (R1, R2 V1.0): + * ESP8266 for WiFi/ESPHome + * Embedded EFM8BB1 microcontroller for 433 MHz +* The white Sonoff RF Bridge (R2 V2.0): + * ESP8266 for WiFi/ESPHome + * Embedded OB38S003 microcontroller for 433 MHz
174-177
: Fix typos and clarify raw command functionality.The explanation of raw command functionality contains typos and could be clearer.
-Send a raw command to the onboard radio chip. The OEM RF firmware is able to send raw only for standard signals (usually short), for other signals (B0 transmit), Portisch or Mightymos fimrware is needed. - - -This can be used to send raw RF codes in automations, mainly for protocols that are not supported. +Send a raw command to the onboard radio chip. The OEM RF firmware can only send raw commands for standard signals (usually short). For other signals (B0 transmit), Portisch or Mightymos firmware is required. + +This functionality can be used to send raw RF codes in automations, particularly for protocols that are not supported by the standard firmware.
376-383
: Add explanatory comment for logger configuration.The logger configuration's purpose should be explained for better understanding.
uart: tx_pin: 1 rx_pin: 3 baud_rate: 19200 logger: + # Disable UART logging to avoid interference with RF Bridge communication baud_rate: 0
462-495
: Group related button examples and add descriptions.The button examples would be more useful with grouping and descriptions of their purposes.
+# Sniffing control buttons button: - platform: template name: Advanced sniffing start on_press: then: - rf_bridge.start_advanced_sniffing - platform: template name: Advanced sniffing stop on_press: then: - rf_bridge.stop_advanced_sniffing - platform: template name: Bucket sniffing start on_press: then: - rf_bridge.start_bucket_sniffing +# Utility buttons - platform: template name: Beep on_press: then: - rf_bridge.beep: duration: 100 - platform: template name: "restart radio" id: mcu_reset on_press: then: - rf_bridge.send_raw: raw: 'AAFE55'
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
components/rf_bridge.rst
(15 hunks)
🧰 Additional context used
📓 Path-based instructions (1)
components/rf_bridge.rst (1)
Pattern **
: - Do not generate or add any sequence diagrams
🔇 Additional comments (1)
components/rf_bridge.rst (1)
329-329
: Remove duplicate converter link.The line contains two different links to B1 converters, which might confuse users.
- For this, you can use the tool `BitBucket Converter <https://bbconv.hrbl.pl/>`__ or `B1 Converter <https://jonajona.nl/convertB1.html/>`__ + For this, you can use the `B1 Converter <https://bbconv.hrbl.pl/>`__
id: uart_hub | ||
baud_rate: 19200 | ||
tx_pin: 1 | ||
rx_pin: 3 | ||
|
||
rf_bridge: | ||
id: kitchen_RF_bridge |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Clarify UART configuration to avoid ID confusion.
Based on the PR discussion, the uart_id
is causing confusion. The example should be simplified and include a note about ID usage.
uart:
- id: uart_hub
baud_rate: 19200
tx_pin: 1
rx_pin: 3
rf_bridge:
id: kitchen_RF_bridge
Add this note after the configuration:
.. note::
The UART component's ``id`` is optional and typically not needed for the RF bridge setup.
The ``id`` in the ``rf_bridge`` component is used for referencing the bridge in automations.
Now worries, UART id configuration variable was removed. |
@nagyrobi Is it good to go now? |
Added references to mightymos firmware
Description:
Related issue (if applicable): fixes
Pull request in esphome with YAML changes (if applicable): esphome/esphome#
Checklist:
I am merging into
next
because this is new documentation that has a matching pull-request in esphome as linked above.or
I am merging into
current
because this is a fix, change and/or adjustment in the current documentation and is not for a new component or feature.Link added in
/index.rst
when creating new documents for new components or cookbook.