mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-04 01:49:41 +00:00
3f0f4d520d
If instead of intaking calls, we intake code, we can deploy a fresh contract which makes arbitrary calls *without* attempting to build our abstraction layer over the concept. This should have the same gas costs, as we still have one contract deployment. The new contract only has a constructor, so it should have no actual code and beat the Sandbox in that regard? We do have to call into ourselves to meter the gas, yet we already had to call into the deployed Sandbox to achieve that. Also re-defines the OutInstruction to include tokens, implements OutInstruction-specified gas amounts, bumps the Solidity version, and other such misc changes.
15 lines
312 B
Solidity
15 lines
312 B
Solidity
// SPDX-License-Identifier: AGPL-3.0-only
|
|
pragma solidity ^0.8.26;
|
|
|
|
import "../Schnorr.sol";
|
|
|
|
contract TestSchnorr {
|
|
function verify(
|
|
bytes32 public_key,
|
|
bytes calldata message,
|
|
bytes32 c,
|
|
bytes32 s
|
|
) external pure returns (bool) {
|
|
return Schnorr.verify(public_key, message, c, s);
|
|
}
|
|
}
|