Some checks failed
Integration Tests / test-service-integration (push) Successful in 2m16s
Package Tests / Python package - aitbc-agent-sdk (push) Successful in 25s
Package Tests / Python package - aitbc-core (push) Successful in 22s
Package Tests / Python package - aitbc-crypto (push) Successful in 14s
Package Tests / Python package - aitbc-sdk (push) Successful in 18s
Package Tests / JavaScript package - aitbc-sdk-js (push) Successful in 6s
Package Tests / JavaScript package - aitbc-token (push) Successful in 21s
Production Tests / Production Integration Tests (push) Failing after 10s
Python Tests / test-python (push) Failing after 2m41s
Security Scanning / security-scan (push) Failing after 46s
Smart Contract Tests / test-solidity (map[name:aitbc-token path:packages/solidity/aitbc-token]) (push) Successful in 16s
Smart Contract Tests / lint-solidity (push) Successful in 12s
- Simplified npm install commands in CI workflows by removing fallback logic - Added aitbc-crypto local dependency installation for aitbc-sdk in package-tests.yml - Removed aitbc-token specific Hardhat dependency workarounds from package-tests.yml - Fixed bare except clause in agent_daemon.py to catch specific json.JSONDecodeError - Moved aitbc-crypto from poetry.dependencies to standard dependencies in aitbc-sdk - Fixed MyPy type errors in receip
87 lines
2.5 KiB
TypeScript
87 lines
2.5 KiB
TypeScript
import type { HardhatEthers } from "@nomicfoundation/hardhat-ethers/types";
|
|
import { network } from "hardhat";
|
|
import type { NetworkConnection } from "hardhat/types/network";
|
|
import { AIToken__factory } from "../typechain-types";
|
|
|
|
type HardhatConnection = NetworkConnection & {
|
|
ethers: HardhatEthers;
|
|
};
|
|
|
|
type HexString = `0x${string}`;
|
|
|
|
type EnvValue = string & {};
|
|
|
|
function requireEnv(name: string): EnvValue {
|
|
const value = process.env[name]?.trim();
|
|
if (!value) {
|
|
throw new Error(`Missing required environment variable ${name}`);
|
|
}
|
|
return value as EnvValue;
|
|
}
|
|
|
|
function parseUnits(value: string): bigint {
|
|
try {
|
|
if (value.startsWith("0x") || value.startsWith("0X")) {
|
|
return BigInt(value);
|
|
}
|
|
return BigInt(value);
|
|
} catch (error) {
|
|
throw new Error(
|
|
`UNITS must be a BigInt-compatible value, received ${value}`,
|
|
);
|
|
}
|
|
}
|
|
|
|
function assertHex(value: string, name: string): HexString {
|
|
if (!value.startsWith("0x") && !value.startsWith("0X")) {
|
|
throw new Error(`${name} must be 0x-prefixed`);
|
|
}
|
|
return value.toLowerCase() as HexString;
|
|
}
|
|
|
|
async function main() {
|
|
const { ethers } = (await network.connect()) as HardhatConnection;
|
|
const contractAddress = assertHex(
|
|
requireEnv("AITOKEN_ADDRESS"),
|
|
"AITOKEN_ADDRESS",
|
|
);
|
|
const providerAddress = requireEnv("PROVIDER_ADDRESS");
|
|
const units = parseUnits(requireEnv("UNITS"));
|
|
const receiptHash = assertHex(requireEnv("RECEIPT_HASH"), "RECEIPT_HASH");
|
|
const signature = assertHex(
|
|
requireEnv("ATTESTOR_SIGNATURE"),
|
|
"ATTESTOR_SIGNATURE",
|
|
);
|
|
|
|
const coordinatorIndex = Number(process.env.COORDINATOR_SIGNER_INDEX ?? "1");
|
|
const signers = await ethers.getSigners();
|
|
const coordinator = signers[coordinatorIndex];
|
|
if (!coordinator) {
|
|
throw new Error(
|
|
`COORDINATOR_SIGNER_INDEX=${coordinatorIndex} does not correspond to an available signer`,
|
|
);
|
|
}
|
|
|
|
console.log("Using coordinator signer:", coordinator.address);
|
|
console.log("Minting receipt for provider:", providerAddress);
|
|
console.log("Units:", units.toString());
|
|
|
|
const token = AIToken__factory.connect(contractAddress, coordinator);
|
|
const tx = await token.mintWithReceipt(
|
|
providerAddress,
|
|
units,
|
|
receiptHash,
|
|
signature,
|
|
);
|
|
const receipt = await tx.wait();
|
|
|
|
console.log("Mint transaction hash:", receipt?.hash ?? tx.hash);
|
|
const balance = await token.balanceOf(providerAddress);
|
|
console.log("Provider balance:", balance.toString());
|
|
}
|
|
|
|
main().catch((error) => {
|
|
console.error(error);
|
|
process.exitCode = 1;
|
|
});
|