mirror of
https://github.com/codex-storage/codex-contracts-eth.git
synced 2025-01-09 19:36:19 +00:00
Prevent withdrawal of locked collateral
This commit is contained in:
parent
c5fab40535
commit
91a976a007
@ -2,8 +2,9 @@
|
|||||||
pragma solidity ^0.8.0;
|
pragma solidity ^0.8.0;
|
||||||
|
|
||||||
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
|
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";
|
||||||
|
import "./AccountLocks.sol";
|
||||||
|
|
||||||
contract Collateral {
|
contract Collateral is AccountLocks {
|
||||||
IERC20 private immutable token;
|
IERC20 private immutable token;
|
||||||
Totals private totals;
|
Totals private totals;
|
||||||
mapping(address => uint256) private balances;
|
mapping(address => uint256) private balances;
|
||||||
@ -38,6 +39,7 @@ contract Collateral {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function withdraw() public invariant {
|
function withdraw() public invariant {
|
||||||
|
_unlockAccount();
|
||||||
uint256 amount = balanceOf(msg.sender);
|
uint256 amount = balanceOf(msg.sender);
|
||||||
totals.withdrawn += amount;
|
totals.withdrawn += amount;
|
||||||
subtract(msg.sender, amount);
|
subtract(msg.sender, amount);
|
||||||
|
@ -11,4 +11,16 @@ contract TestCollateral is Collateral {
|
|||||||
function slash(address account, uint256 percentage) public {
|
function slash(address account, uint256 percentage) public {
|
||||||
_slash(account, percentage);
|
_slash(account, percentage);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function createLock(bytes32 id, uint256 expiry) public {
|
||||||
|
_createLock(id, expiry);
|
||||||
|
}
|
||||||
|
|
||||||
|
function lock(address account, bytes32 id) public {
|
||||||
|
_lock(account, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
function unlock(bytes32 id) public {
|
||||||
|
_unlock(id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
const { expect } = require("chai")
|
const { expect } = require("chai")
|
||||||
|
const { exampleLock } = require("./examples")
|
||||||
|
|
||||||
describe("Collateral", function () {
|
describe("Collateral", function () {
|
||||||
let collateral, token
|
let collateral, token
|
||||||
@ -89,4 +90,25 @@ describe("Collateral", function () {
|
|||||||
expect(await collateral.balanceOf(account1.address)).to.equal(950)
|
expect(await collateral.balanceOf(account1.address)).to.equal(950)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
describe("locking", function () {
|
||||||
|
let lock
|
||||||
|
|
||||||
|
beforeEach(async function () {
|
||||||
|
await token.approve(collateral.address, 42)
|
||||||
|
await collateral.deposit(42)
|
||||||
|
lock = exampleLock()
|
||||||
|
await collateral.createLock(lock.id, lock.expiry)
|
||||||
|
await collateral.lock(account0.address, lock.id)
|
||||||
|
})
|
||||||
|
|
||||||
|
it("withdrawal fails when account is locked", async function () {
|
||||||
|
await expect(collateral.withdraw()).to.be.revertedWith("Account locked")
|
||||||
|
})
|
||||||
|
|
||||||
|
it("withdrawal succeeds when account is unlocked", async function () {
|
||||||
|
await collateral.unlock(lock.id)
|
||||||
|
await expect(collateral.withdraw()).not.to.be.reverted
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user