编译器
0.8.21+commit.d9974bed
文件 1 的 5:AIOracleCallbackReceiver.sol
pragma solidity ^0.8.9;
import "./interfaces/IAIOracle.sol";
abstract contract AIOracleCallbackReceiver {
IAIOracle public immutable aiOracle;
error UnauthorizedCallbackSource(IAIOracle expected, IAIOracle found);
constructor(IAIOracle _aiOracle) {
aiOracle = _aiOracle;
}
modifier onlyAIOracleCallback() {
IAIOracle foundRelayAddress = IAIOracle(msg.sender);
if (foundRelayAddress != aiOracle) {
revert UnauthorizedCallbackSource(aiOracle, foundRelayAddress);
}
_;
}
function aiOracleCallback(uint256 requestId, bytes calldata output, bytes calldata callbackData) external virtual;
function isFinalized(uint256 requestId) external view returns (bool) {
return aiOracle.isFinalized(requestId);
}
}
文件 2 的 5:Context.sol
pragma solidity ^0.8.20;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
function _contextSuffixLength() internal view virtual returns (uint256) {
return 0;
}
}
文件 3 的 5:IAIOracle.sol
pragma solidity ^0.8.9;
interface IAIOracle {
event AICallbackRequest(
address indexed account,
uint256 indexed requestId,
uint256 modelId,
bytes input,
address callbackContract,
uint64 gasLimit,
bytes callbackData
);
event AICallbackResult(
address indexed account,
uint256 indexed requestId,
address invoker,
bytes output
);
function requestCallback(
uint256 modelId,
bytes memory input,
address callbackContract,
uint64 gasLimit,
bytes memory callbackData
) external payable returns (uint256);
function estimateFee(uint256 modelId, uint256 gasLimit) external view returns (uint256);
function isFinalized(uint256 requestId) external view returns (bool);
}
文件 4 的 5:Pausable.sol
pragma solidity ^0.8.20;
import {Context} from "../utils/Context.sol";
abstract contract Pausable is Context {
bool private _paused;
event Paused(address account);
event Unpaused(address account);
error EnforcedPause();
error ExpectedPause();
constructor() {
_paused = false;
}
modifier whenNotPaused() {
_requireNotPaused();
_;
}
modifier whenPaused() {
_requirePaused();
_;
}
function paused() public view virtual returns (bool) {
return _paused;
}
function _requireNotPaused() internal view virtual {
if (paused()) {
revert EnforcedPause();
}
}
function _requirePaused() internal view virtual {
if (!paused()) {
revert ExpectedPause();
}
}
function _pause() internal virtual whenNotPaused {
_paused = true;
emit Paused(_msgSender());
}
function _unpause() internal virtual whenPaused {
_paused = false;
emit Unpaused(_msgSender());
}
}
文件 5 的 5:Prompt.sol
pragma solidity ^0.8.13;
import {IAIOracle} from "OAO/contracts/interfaces/IAIOracle.sol";
import {AIOracleCallbackReceiver} from "OAO/contracts/AIOracleCallbackReceiver.sol";
import "@openzeppelin/contracts/utils/Pausable.sol";
contract Prompt is AIOracleCallbackReceiver, Pausable {
event promptsUpdated(
uint256 requestId,
uint256 modelId,
string input,
string output,
bytes callbackData
);
event ScoreUpdated(address indexed user, uint8 newScore);
event promptRequest(
uint256 requestId,
address sender,
uint256 modelId,
string prompt
);
struct AIOracleRequest {
address sender;
uint256 modelId;
bytes input;
bytes output;
}
address public owner;
string private systemPrompt =
"7007 protocol tokenizes AI outputs as unique inference assets, each representing a specific AI-generated data piece. This protocol makes AI inferences verifiable, immutable, and non-fungible, securing data and computation integrity on the blockchain. You are rating community members engagement with and potential to improve a crypto project. Rate replies based on: 0-10: The reply does not contribute value or is unclear/incomplete/short. 20-50: The member only wants financial incentive only but provides insufficient details to introduce their potential contribution. 60-90: The member could potentially improve the project and explains their plans and contribution convincingly. 90-100: The reply shows special passion and benefits for the project. You must output only the score in the format: ";
modifier onlyOwner() {
require(msg.sender == owner, "Only owner");
_;
}
mapping(uint256 => AIOracleRequest) public requests;
mapping(uint256 => uint64) public callbackGasLimit;
mapping(address => uint8) public addressScore;
address[] public scoredAddresses;
mapping(address => bool) public isAddressScored;
constructor(IAIOracle _aiOracle) AIOracleCallbackReceiver(_aiOracle) {
owner = msg.sender;
callbackGasLimit[14] = 2_500_000;
}
function setCallbackGasLimit(
uint256 modelId,
uint64 gasLimit
) external onlyOwner {
callbackGasLimit[modelId] = gasLimit;
}
mapping(uint256 => mapping(string => string)) public prompts;
function getAIResult(
uint256 modelId,
string calldata prompt
) external view returns (string memory) {
string memory input = string(
abi.encodePacked(
'{"instruction":"',
systemPrompt,
'",',
'"input": "',
prompt,
'"}'
)
);
return prompts[modelId][input];
}
function pause() external onlyOwner {
_pause();
}
function unpause() external onlyOwner {
_unpause();
}
function aiOracleCallback(
uint256 requestId,
bytes calldata output,
bytes calldata callbackData
) external override onlyAIOracleCallback {
AIOracleRequest storage request = requests[requestId];
require(request.sender != address(0), "request does not exist");
request.output = output;
prompts[request.modelId][string(request.input)] = string(output);
uint8 outputScore = safelyConvertToScore(output);
address sender = request.sender;
addressScore[sender] = outputScore;
emit ScoreUpdated(sender, outputScore);
if (!isAddressScored[sender]) {
scoredAddresses.push(sender);
isAddressScored[sender] = true;
}
emit promptsUpdated(
requestId,
request.modelId,
string(request.input),
string(output),
callbackData
);
}
function safelyConvertToScore(bytes memory b) public pure returns (uint8) {
if (b.length == 0) return 50;
uint16 score = 0;
bool hasValidDigit = false;
for (uint i = 0; i < b.length; i++) {
uint8 currentByte = uint8(b[i]);
if (currentByte >= 48 && currentByte <= 57) {
if (score == 0 && currentByte == 48 && !hasValidDigit) {
continue;
}
hasValidDigit = true;
score = score * 10 + (currentByte - 48);
if (score > 100) {
return 50;
}
} else if (hasValidDigit) {
break;
}
}
if (!hasValidDigit) {
return 50;
}
return uint8(score);
}
function getWhitelist() public view returns (address[] memory) {
return scoredAddresses;
}
function getWhitelistLength() public view returns (uint256) {
return scoredAddresses.length;
}
function estimateFee(uint256 modelId) public view returns (uint256) {
return aiOracle.estimateFee(modelId, callbackGasLimit[modelId]);
}
function setSystemPrompt(string calldata _systemPrompt) external onlyOwner {
systemPrompt = _systemPrompt;
}
uint256 public startTime = 1725879600;
uint256 public endTime = 1726052400;
function getStartTime() public view returns (uint256) {
return startTime;
}
function getEndTime() public view returns (uint256) {
return endTime;
}
function getStartRemainingTime() public view returns (uint256) {
require(block.timestamp >= startTime, "Claim Token Phase Not Open");
return startTime - block.timestamp;
}
function getEndRemainingTime() public view returns (uint256) {
require(block.timestamp <= endTime, "Claim Token Phase Ended");
return endTime - block.timestamp;
}
function setStartTime(uint256 _startTime) public onlyOwner {
startTime = _startTime;
}
function setEndTime(uint256 _endTime) public onlyOwner {
endTime = _endTime;
}
function calculateAIResult(
uint256 modelId,
string calldata prompt
) external payable whenNotPaused returns (uint256) {
require(block.timestamp >= startTime, "Phase Not Open");
require(block.timestamp <= endTime, "Phase Ended");
bytes memory input = bytes(
abi.encodePacked(
'{"instruction":"',
systemPrompt,
'",',
'"input": "',
prompt,
'"}'
)
);
uint256 requestId = aiOracle.requestCallback{value: msg.value}(
modelId,
input,
address(this),
callbackGasLimit[modelId],
""
);
AIOracleRequest storage request = requests[requestId];
request.input = input;
request.sender = msg.sender;
request.modelId = modelId;
emit promptRequest(requestId, msg.sender, modelId, prompt);
return requestId;
}
}
{
"compilationTarget": {
"src/Prompt.sol": "Prompt"
},
"evmVersion": "paris",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": [
":@openzeppelin/contracts/=node_modules/@openzeppelin/contracts/",
":@prb-math/=lib/prb-math/src/",
":@prb/math/=lib/prb-math/src/",
":@prb/test/=lib/prb-math/lib/prb-test/src/",
":OAO/=lib/OAO/",
":ds-test/=lib/prb-math/lib/forge-std/lib/ds-test/src/",
":forge-std/=lib/forge-std/src/",
":prb-math/=lib/prb-math/src/",
":prb-test/=lib/prb-math/lib/prb-test/src/",
":src/=src/"
]
}
[{"inputs":[{"internalType":"contract IAIOracle","name":"_aiOracle","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"EnforcedPause","type":"error"},{"inputs":[],"name":"ExpectedPause","type":"error"},{"inputs":[{"internalType":"contract IAIOracle","name":"expected","type":"address"},{"internalType":"contract IAIOracle","name":"found","type":"address"}],"name":"UnauthorizedCallbackSource","type":"error"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"uint8","name":"newScore","type":"uint8"}],"name":"ScoreUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"requestId","type":"uint256"},{"indexed":false,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"uint256","name":"modelId","type":"uint256"},{"indexed":false,"internalType":"string","name":"prompt","type":"string"}],"name":"promptRequest","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"requestId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"modelId","type":"uint256"},{"indexed":false,"internalType":"string","name":"input","type":"string"},{"indexed":false,"internalType":"string","name":"output","type":"string"},{"indexed":false,"internalType":"bytes","name":"callbackData","type":"bytes"}],"name":"promptsUpdated","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"addressScore","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"aiOracle","outputs":[{"internalType":"contract IAIOracle","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"requestId","type":"uint256"},{"internalType":"bytes","name":"output","type":"bytes"},{"internalType":"bytes","name":"callbackData","type":"bytes"}],"name":"aiOracleCallback","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"modelId","type":"uint256"},{"internalType":"string","name":"prompt","type":"string"}],"name":"calculateAIResult","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"callbackGasLimit","outputs":[{"internalType":"uint64","name":"","type":"uint64"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"endTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"modelId","type":"uint256"}],"name":"estimateFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"modelId","type":"uint256"},{"internalType":"string","name":"prompt","type":"string"}],"name":"getAIResult","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getEndRemainingTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getEndTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getStartRemainingTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getStartTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getWhitelist","outputs":[{"internalType":"address[]","name":"","type":"address[]"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getWhitelistLength","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isAddressScored","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"requestId","type":"uint256"}],"name":"isFinalized","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"string","name":"","type":"string"}],"name":"prompts","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"requests","outputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"uint256","name":"modelId","type":"uint256"},{"internalType":"bytes","name":"input","type":"bytes"},{"internalType":"bytes","name":"output","type":"bytes"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes","name":"b","type":"bytes"}],"name":"safelyConvertToScore","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"scoredAddresses","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"modelId","type":"uint256"},{"internalType":"uint64","name":"gasLimit","type":"uint64"}],"name":"setCallbackGasLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_endTime","type":"uint256"}],"name":"setEndTime","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_startTime","type":"uint256"}],"name":"setStartTime","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_systemPrompt","type":"string"}],"name":"setSystemPrompt","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"}]