Skip to content

Commit

Permalink
Add documentation on unprotected-update-current-contract-wasm detector
Browse files Browse the repository at this point in the history
  • Loading branch information
arturoBeccar authored Dec 1, 2023
1 parent 66686d0 commit f911826
Showing 1 changed file with 56 additions and 0 deletions.
56 changes: 56 additions & 0 deletions detectors/unprotected-update-current-contract-wasm/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
# Unprotected update of current contract wasm

### What it does

It warns you if `update_current_contract_wasm()` function is called without a previous check of the address of the caller.

### Why is this bad?

If users are allowed to call `update_current_contract_wasm()`, they can intentionally modify the contract behaviour, leading to the loss of all associated data/tokens and functionalities given by this contract or by others that depend on it.

### Example

```rust
#[contractimpl]
impl UpgradeableContract {
pub fn init(e: Env, admin: Address) {
e.storage().instance().set(&DataKey::Admin, &admin);
}

pub fn version() -> u32 {
1
}

pub fn upgrade(e: Env, new_wasm_hash: BytesN<32>) {
let admin: Address = e.storage().instance().get(&DataKey::Admin).unwrap();

e.deployer().update_current_contract_wasm(new_wasm_hash);
}
}
```

Use instead:

```rust
#[contractimpl]
impl UpgradeableContract {
pub fn init(e: Env, admin: Address) {
e.storage().instance().set(&DataKey::Admin, &admin);
}

pub fn version() -> u32 {
1
}

pub fn upgrade(e: Env, new_wasm_hash: BytesN<32>) {
let admin: Address = e.storage().instance().get(&DataKey::Admin).unwrap();
admin.require_auth();

e.deployer().update_current_contract_wasm(new_wasm_hash);
}
}
```

### Implementation

The detector's implementation can be found at [this link](https://github.com/CoinFabrik/scout-soroban/tree/main/detectors/unprotected-update-current-contract-wasm)

0 comments on commit f911826

Please sign in to comment.