Gude PDU support#334
Open
JonasLoeffelholz wants to merge 1 commit into
Open
Conversation
e54c6e4 to
077bcce
Compare
077bcce to
b5081f0
Compare
jenstopp
reviewed
Jun 1, 2026
jenstopp
left a comment
Member
There was a problem hiding this comment.
Nice approach with the backend!
Need to look at the explicit implementations in more depth (it looks a bit weird that the general PDU type has an interface and the concrete implementations need that general type itself passed during their init).
Anyway, here is some first feedback.
b5081f0 to
34e3572
Compare
34e3572 to
519899d
Compare
*adds support for flexible pdu apis through backend interface pattern *moves intellinet (style) api interface to separate file *adds support for gude api Signed-off-by: jonas loeffelholz <jonas.loeffelholz@9elements.com>
519899d to
b94832f
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Add Multi-PDU Support with Gude Implementation
Summary
This PR refactors the PDU module to support multiple PDU vendors through a pluggable interface architecture and adds full support for Gude brand PDUs. The original Intellinet/LogiLink-specific implementation has been abstracted to support different PDU types while maintaining backward compatibility.
Architecture Refactoring
Introduced PDU backend interface pattern: Created a pluggable architecture where different PDU implementations conform to a common interface
Extracted Intellinet implementation: Moved Intellinet/LogiLink-specific code from pdu.go to intellinet.go
Simplified core PDU logic: pdu.go now acts as a dispatcher that delegates to the appropriate backend based on pdutype configuratio
Gude PDU
Implemented Support for GUDE PDU API (for currently supported functionality of the pre existant PDU module)