revamp script

Signed-off-by: microwavedcola1 <microwavedcola@gmail.com>
This commit is contained in:
microwavedcola1 2022-08-10 09:26:16 +02:00
parent dd05fade76
commit 2728aaeb2d
1 changed files with 165 additions and 99 deletions

View File

@ -10,12 +10,20 @@ import { MANGO_V4_ID } from '../constants';
const MAINNET_MINTS = new Map([
['USDC', 'EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v'],
['USDT', 'Es9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB'],
['BTC', '9n4nbM75f5Ui33ZbPYXn59EwSgE8CGsHtAeTH5YFeJ9E'],
['ETH', '2FPyTwcZLUg1MDrwsyoP4D6s1tM7hAkHYRjkNb5w6Pxk'],
['SOL', 'So11111111111111111111111111111111111111112'],
['MSOL', 'mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So'],
['MNGO', 'MangoCzJ36AjZyKwVj3VnYU4GTonjfVEnJmvvWaxLac'],
]);
const MAINNET_ORACLES = new Map([
['USDT', '3vxLXJqLqF3JG5TCbYycbKWRBbCJQLxQmBGCkyqEEefL'],
['BTC', 'GVXRSBjFk6e6J3NbVPXohDJetcTjaeeuykUpbQF8UoMU'],
['ETH', 'JBu1AL4obBcCMqKBBxhpWCNUt136ijcuMZLFvTP7iWdB'],
['SOL', 'H6ARHf6YXhGYeQfUzQNGk6rDNnLBQKrenN712K4AQJEG'],
['MSOL', 'E4v1BBgoso9s64TQvmyownAVJbhbEPGyzA3qn4n46qj9'],
['MNGO', '79wm3jjcPr6RaNQ4DGvP5KxG1mNd3gEBsg6FsNVFezK4'],
]);
async function main() {
@ -38,127 +46,185 @@ async function main() {
// group
console.log(`Creating Group...`);
try {
const insuranceMint = new PublicKey(MAINNET_MINTS.get('USDC')!);
await client.groupCreate(0, true, 0, insuranceMint);
} catch (error) {
console.log(error);
}
const insuranceMint = new PublicKey(MAINNET_MINTS.get('USDC')!);
await client.groupCreate(0, true, 0, insuranceMint);
const group = await client.getGroupForCreator(admin.publicKey);
console.log(`...registered group ${group.publicKey}`);
// register token 1
console.log(`Registering BTC...`);
const btcMainnetMint = new PublicKey(MAINNET_MINTS.get('BTC')!);
const btcMainnetOracle = new PublicKey(MAINNET_ORACLES.get('BTC')!);
try {
await client.tokenRegister(
group,
btcMainnetMint,
btcMainnetOracle,
0.1,
1,
'BTC',
0.01,
0.4,
0.07,
0.7,
0.88,
1.5,
0.0005,
1.5,
0.9,
0.8,
1.1,
1.2,
0.05,
);
await group.reloadAll(client);
} catch (error) {
console.log(error);
}
// stub oracle + register token 0
console.log(`Creating USDC stub oracle...`);
const usdcMainnetMint = new PublicKey(MAINNET_MINTS.get('USDC')!);
try {
await client.stubOracleCreate(group, usdcMainnetMint, 1.0);
} catch (error) {
console.log(error);
}
await client.stubOracleCreate(group, usdcMainnetMint, 1.0);
const usdcMainnetOracle = (
await client.getStubOracle(group, usdcMainnetMint)
)[0];
console.log(`...created stub oracle ${usdcMainnetOracle.publicKey}`);
console.log(`Registering USDC...`);
try {
await client.tokenRegister(
group,
usdcMainnetMint,
usdcMainnetOracle.publicKey,
0.1,
0,
'USDC',
0.01,
0.4,
0.07,
0.8,
0.9,
1.5,
0.0005,
1.5,
1,
1,
1,
1,
0,
);
await group.reloadAll(client);
} catch (error) {
console.log(error);
}
await client.tokenRegister(
group,
usdcMainnetMint,
usdcMainnetOracle.publicKey,
0.1,
0,
'USDC',
0.004,
0.4,
0.07,
0.8,
0.9,
1.5,
0.005,
0.0005,
1,
1,
1,
1,
0,
);
console.log(`Registering USDT...`);
const usdtMainnetMint = new PublicKey(MAINNET_MINTS.get('USDT')!);
const usdtMainnetOracle = new PublicKey(MAINNET_ORACLES.get('USDT')!);
await client.tokenRegister(
group,
usdtMainnetMint,
usdtMainnetOracle,
0.1,
1,
'USDT',
0.004,
0.4,
0.07,
0.8,
0.9,
1.5,
0.005,
0.0005,
0.95,
0.9,
1.05,
1.1,
0.02,
);
console.log(`Registering BTC...`);
const btcMainnetMint = new PublicKey(MAINNET_MINTS.get('BTC')!);
const btcMainnetOracle = new PublicKey(MAINNET_ORACLES.get('BTC')!);
await client.tokenRegister(
group,
btcMainnetMint,
btcMainnetOracle,
0.1,
2,
'BTC',
0.004,
0.4,
0.07,
0.8,
0.9,
1.5,
0.005,
0.0005,
0.9,
0.8,
1.1,
1.2,
0.05,
);
console.log(`Registering ETH...`);
const ethMainnetMint = new PublicKey(MAINNET_MINTS.get('ETH')!);
const ethMainnetOracle = new PublicKey(MAINNET_ORACLES.get('ETH')!);
await client.tokenRegister(
group,
ethMainnetMint,
ethMainnetOracle,
0.1,
3,
'ETH',
0.004,
0.4,
0.07,
0.8,
0.9,
1.5,
0.005,
0.0005,
0.9,
0.8,
1.1,
1.2,
0.05,
);
// register token 2
console.log(`Registering SOL...`);
const solMainnetMint = new PublicKey(MAINNET_MINTS.get('SOL')!);
const solMainnetOracle = new PublicKey(MAINNET_ORACLES.get('SOL')!);
try {
await client.tokenRegister(
group,
solMainnetMint,
solMainnetOracle,
0.1,
2, // tokenIndex
'SOL',
0.01,
0.4,
0.07,
0.8,
0.9,
1.5,
0.0005,
1.5,
0.9,
0.8,
1.1,
1.2,
0.05,
);
await group.reloadAll(client);
} catch (error) {
console.log(error);
}
await client.tokenRegister(
group,
solMainnetMint,
solMainnetOracle,
0.1,
4,
'SOL',
0.004,
0.4,
0.07,
0.8,
0.9,
1.5,
0.005,
0.0005,
0.9,
0.8,
1.1,
1.2,
0.05,
);
console.log(`Registering MSOL...`);
const msolMainnetMint = new PublicKey(MAINNET_MINTS.get('MSOL')!);
const msolMainnetOracle = new PublicKey(MAINNET_ORACLES.get('MSOL')!);
await client.tokenRegister(
group,
msolMainnetMint,
msolMainnetOracle,
0.1,
5,
'MSOL',
0.004,
0.4,
0.07,
0.8,
0.9,
1.5,
0.005,
0.0005,
0.9,
0.8,
1.1,
1.2,
0.05,
);
console.log(`Registering MNGO...`);
const mngoMainnetMint = new PublicKey(MAINNET_MINTS.get('MNGO')!);
const mngoMainnetOracle = new PublicKey(MAINNET_ORACLES.get('MNGO')!);
await client.tokenRegisterTrustless(
group,
mngoMainnetMint,
mngoMainnetOracle,
6,
'MNGO',
);
// log tokens/banks
await group.reloadAll(client);
for (const bank of await group.banksMap.values()) {
console.log(`${bank.toString()}`);
}
console.log(
`NOTE: run yarn ts-node ts/client/src/scripts/mb-add-group-to-ids-json.ts to update ids json`,
);
process.exit();
}