Skip to content

Lack of proper validation of server UUID can be used by the server to trick the client to accept invalid proofs

Moderate severity GitHub Reviewed Published Nov 21, 2022 in codenotary/immudb • Updated Feb 14, 2023

Package

gomod github.com/codenotary/immudb (Go)

Affected versions

< 1.4.1

Patched versions

1.4.1

Description

Impact

immudb client SDKs use server's UUID to distinguish between different server instance so that the client can connect to different immudb instances and keep the state for multiple servers. SDK does not validate this uuid and can accept any value reported by the server. A malicious server can change the reported UUID tricking the client to treat it as a different server thus accepting a state completely irrelevant to the one previously retrieved from the server.

Patches

The following Go SDK versions are not vulnerable:

SDK Version
go 1.4.1

Workarounds

When initializing an immudb client object, a custom state handler can be used to store the state. Providing custom implementation that ignores the server UUID can be used to ensure that even if the server changes the UUID, client will still consider it to be the same server.

For more information

If you have any questions or comments about this advisory:

References

@byo byo published to codenotary/immudb Nov 21, 2022
Published to the GitHub Advisory Database Nov 21, 2022
Reviewed Nov 21, 2022
Published by the National Vulnerability Database Nov 22, 2022
Last updated Feb 14, 2023

Severity

Moderate
5.8
/ 10

CVSS base metrics

Attack vector
Network
Attack complexity
High
Privileges required
High
User interaction
None
Scope
Changed
Confidentiality
None
Integrity
High
Availability
None
CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:C/C:N/I:H/A:N

Weaknesses

CVE ID

CVE-2022-39199

GHSA ID

GHSA-6cqj-6969-p57x

Source code

Checking history
See something to contribute? Suggest improvements for this vulnerability.