generated from NomicFoundation/hardhat-boilerplate
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathCowswapOrderSigner.sol
61 lines (49 loc) · 1.87 KB
/
CowswapOrderSigner.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
// SPDX-License-Identifier: MIT
// implementation based on https://gist.github.com/Arachnid/6950b3367258b5d5033f6e1c411086e8
// cowswap contracts taken from https://github.com/cowprotocol/contracts/releases/tag/v1.3.2
pragma solidity ^0.8.12;
import "./cowProtocol/libraries/GPv2Order.sol";
import "./cowProtocol/mixins/GPv2Signing.sol";
import "./cowProtocol/interfaces/IERC20.sol";
contract CowswapOrderSigner {
using GPv2Order for GPv2Order.Data;
using GPv2Order for bytes;
GPv2Signing public immutable signing;
bytes32 public immutable domainSeparator;
address public immutable deployedAt;
constructor(GPv2Signing _signing) {
require(address(_signing) != address(0), "Invalid signing address");
signing = _signing;
domainSeparator = _signing.domainSeparator();
deployedAt = address(this);
}
function _setPreSignature(
GPv2Order.Data calldata order,
bool signed
) internal {
require(address(this) != deployedAt, "DELEGATECALL only");
// compute order UID
bytes32 orderDigest = order.hash(domainSeparator);
bytes memory orderUid = new bytes(GPv2Order.UID_LENGTH);
orderUid.packOrderUidParams(orderDigest, address(this), order.validTo);
signing.setPreSignature(orderUid, signed);
}
function signOrder(
GPv2Order.Data calldata order,
uint32 validDuration, // seconds
uint256 feeAmountBP // basis points
) external {
require(
block.timestamp + validDuration > order.validTo,
"Dishonest valid duration"
);
require(
order.feeAmount <= (order.sellAmount * feeAmountBP) / 100_00 + 1,
"Fee too high"
);
_setPreSignature(order, true);
}
function unsignOrder(GPv2Order.Data calldata order) external {
_setPreSignature(order, false);
}
}