Bug #19457
closedEnforce stricter restriction on authorized node id and hostname
Description
Currently the webapp allows anything in the [a-zA-Z0-9\-]
range (which includes things like --insecure
while on agent side the inventory check script is much stricter and checks for:
($uuid ne "root" \&\& $uuid !~ /[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/i))
As this check is already present at inventory creation, we can apply it pretty safely on the webapp side, or a at least prevent dash as first char.
This would avoid option injection in commands using node id as argument.
For hostnames, currently toto " $ <b>tutu</b><script>alert(1);</script>
is accepted as a valid hostname.
Given the hostname is used in several places, including command arguments, it could be a good thing to restrict its content to a reasonable char set to prevent various injections.
Updated by François ARMAND about 3 years ago
- Related to Bug #19456: Lack of HTML escaping in nodes list added
Updated by François ARMAND about 3 years ago
- Subject changed from Enforce stricter restriction on authorized node id to Enforce stricter restriction on authorized node id and hostname
I'm merging #19458 with that one, since the check will happen at the same place (when an inventory is processed for UX, and when an inventory is saved for security and deal with case where the inventory is not processed in the default path).
Updated by François ARMAND about 3 years ago
- Description updated (diff)
- Severity set to Minor - inconvenience | misleading | easy workaround
- User visibility set to Operational - other Techniques | Rudder settings | Plugins
- Effort required set to Very Small
- Priority changed from 0 to 61
Updated by François ARMAND about 3 years ago
- Status changed from New to In progress
- Assignee set to François ARMAND
Updated by François ARMAND about 3 years ago
- Has duplicate Bug #19458: Validate the hostname field added
Updated by François ARMAND about 3 years ago
- Status changed from In progress to Pending technical review
- Assignee changed from François ARMAND to Vincent MEMBRÉ
- Pull Request set to https://github.com/Normation/rudder/pull/3686
Updated by François ARMAND about 3 years ago
- Status changed from Pending technical review to Pending release
Applied in changeset rudder|05489d2060551ecbf62c13245a43dad2ad2704b1.
Updated by Alexis Mousset about 3 years ago
- Fix check changed from To do to Checked
Updated by Vincent MEMBRÉ about 3 years ago
- Status changed from Pending release to Released
This bug has been fixed in Rudder 6.1.14 and 6.2.8 which were released today.
Updated by Alexis Mousset about 1 year ago
- Private changed from Yes to No
- Priority changed from 61 to 0