default group is group num 2 on mainnet
Signed-off-by: microwavedcola1 <microwavedcola@gmail.com>
This commit is contained in:
parent
5221bbd53b
commit
d59d05eae5
|
@ -4,15 +4,12 @@ import fs from 'fs';
|
||||||
import { MangoClient } from '../client';
|
import { MangoClient } from '../client';
|
||||||
import { MANGO_V4_ID } from '../constants';
|
import { MANGO_V4_ID } from '../constants';
|
||||||
|
|
||||||
//
|
|
||||||
// Script which depoys a new mango group, and registers 3 tokens
|
|
||||||
//
|
|
||||||
|
|
||||||
const MAINNET_MINTS = new Map([
|
const MAINNET_MINTS = new Map([
|
||||||
['USDC', 'EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v'],
|
['USDC', 'EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v'],
|
||||||
['USDT', 'Es9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB'],
|
['USDT', 'Es9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB'],
|
||||||
['BTC', '9n4nbM75f5Ui33ZbPYXn59EwSgE8CGsHtAeTH5YFeJ9E'],
|
['BTC', '9n4nbM75f5Ui33ZbPYXn59EwSgE8CGsHtAeTH5YFeJ9E'], // Wrapped Bitcoin (Sollet)
|
||||||
['ETH', '2FPyTwcZLUg1MDrwsyoP4D6s1tM7hAkHYRjkNb5w6Pxk'],
|
['ETH', '7vfCXTUXx5WJV5JADk17DUJ4ksgau7utNKj4b963voxs'], // Ether (Portal)
|
||||||
|
['soETH', '2FPyTwcZLUg1MDrwsyoP4D6s1tM7hAkHYRjkNb5w6Pxk'], // Wrapped Ethereum (Sollet)
|
||||||
['SOL', 'So11111111111111111111111111111111111111112'],
|
['SOL', 'So11111111111111111111111111111111111111112'],
|
||||||
['MSOL', 'mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So'],
|
['MSOL', 'mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So'],
|
||||||
['MNGO', 'MangoCzJ36AjZyKwVj3VnYU4GTonjfVEnJmvvWaxLac'],
|
['MNGO', 'MangoCzJ36AjZyKwVj3VnYU4GTonjfVEnJmvvWaxLac'],
|
||||||
|
@ -21,20 +18,22 @@ const MAINNET_ORACLES = new Map([
|
||||||
['USDT', '3vxLXJqLqF3JG5TCbYycbKWRBbCJQLxQmBGCkyqEEefL'],
|
['USDT', '3vxLXJqLqF3JG5TCbYycbKWRBbCJQLxQmBGCkyqEEefL'],
|
||||||
['BTC', 'GVXRSBjFk6e6J3NbVPXohDJetcTjaeeuykUpbQF8UoMU'],
|
['BTC', 'GVXRSBjFk6e6J3NbVPXohDJetcTjaeeuykUpbQF8UoMU'],
|
||||||
['ETH', 'JBu1AL4obBcCMqKBBxhpWCNUt136ijcuMZLFvTP7iWdB'],
|
['ETH', 'JBu1AL4obBcCMqKBBxhpWCNUt136ijcuMZLFvTP7iWdB'],
|
||||||
|
['soETH', 'JBu1AL4obBcCMqKBBxhpWCNUt136ijcuMZLFvTP7iWdB'],
|
||||||
['SOL', 'H6ARHf6YXhGYeQfUzQNGk6rDNnLBQKrenN712K4AQJEG'],
|
['SOL', 'H6ARHf6YXhGYeQfUzQNGk6rDNnLBQKrenN712K4AQJEG'],
|
||||||
['MSOL', 'E4v1BBgoso9s64TQvmyownAVJbhbEPGyzA3qn4n46qj9'],
|
['MSOL', 'E4v1BBgoso9s64TQvmyownAVJbhbEPGyzA3qn4n46qj9'],
|
||||||
['MNGO', '79wm3jjcPr6RaNQ4DGvP5KxG1mNd3gEBsg6FsNVFezK4'],
|
['MNGO', '79wm3jjcPr6RaNQ4DGvP5KxG1mNd3gEBsg6FsNVFezK4'],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
async function main() {
|
async function createGroup() {
|
||||||
const options = AnchorProvider.defaultOptions();
|
|
||||||
const connection = new Connection(process.env.MB_CLUSTER_URL, options);
|
|
||||||
|
|
||||||
const admin = Keypair.fromSecretKey(
|
const admin = Keypair.fromSecretKey(
|
||||||
Buffer.from(
|
Buffer.from(
|
||||||
JSON.parse(fs.readFileSync(process.env.MB_PAYER_KEYPAIR!, 'utf-8')),
|
JSON.parse(fs.readFileSync(process.env.MB_PAYER_KEYPAIR!, 'utf-8')),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const options = AnchorProvider.defaultOptions();
|
||||||
|
const connection = new Connection(process.env.MB_CLUSTER_URL, options);
|
||||||
|
|
||||||
const adminWallet = new Wallet(admin);
|
const adminWallet = new Wallet(admin);
|
||||||
console.log(`Admin ${adminWallet.publicKey.toBase58()}`);
|
console.log(`Admin ${adminWallet.publicKey.toBase58()}`);
|
||||||
const adminProvider = new AnchorProvider(connection, adminWallet, options);
|
const adminProvider = new AnchorProvider(connection, adminWallet, options);
|
||||||
|
@ -44,14 +43,34 @@ async function main() {
|
||||||
MANGO_V4_ID['mainnet-beta'],
|
MANGO_V4_ID['mainnet-beta'],
|
||||||
);
|
);
|
||||||
|
|
||||||
// group
|
|
||||||
console.log(`Creating Group...`);
|
console.log(`Creating Group...`);
|
||||||
const insuranceMint = new PublicKey(MAINNET_MINTS.get('USDC')!);
|
const insuranceMint = new PublicKey(MAINNET_MINTS.get('USDC')!);
|
||||||
await client.groupCreate(0, true, 0, insuranceMint);
|
await client.groupCreate(2, true, 0, insuranceMint);
|
||||||
const group = await client.getGroupForCreator(admin.publicKey);
|
const group = await client.getGroupForCreator(admin.publicKey, 2);
|
||||||
console.log(`...registered group ${group.publicKey}`);
|
console.log(`...registered group ${group.publicKey}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
async function registerTokens() {
|
||||||
|
const admin = Keypair.fromSecretKey(
|
||||||
|
Buffer.from(
|
||||||
|
JSON.parse(fs.readFileSync(process.env.MB_PAYER_KEYPAIR!, 'utf-8')),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
const options = AnchorProvider.defaultOptions();
|
||||||
|
const connection = new Connection(process.env.MB_CLUSTER_URL, options);
|
||||||
|
|
||||||
|
const adminWallet = new Wallet(admin);
|
||||||
|
console.log(`Admin ${adminWallet.publicKey.toBase58()}`);
|
||||||
|
const adminProvider = new AnchorProvider(connection, adminWallet, options);
|
||||||
|
const client = await MangoClient.connect(
|
||||||
|
adminProvider,
|
||||||
|
'mainnet-beta',
|
||||||
|
MANGO_V4_ID['mainnet-beta'],
|
||||||
|
);
|
||||||
|
|
||||||
|
const group = await client.getGroupForCreator(admin.publicKey, 2);
|
||||||
|
|
||||||
// stub oracle + register token 0
|
|
||||||
console.log(`Creating USDC stub oracle...`);
|
console.log(`Creating USDC stub oracle...`);
|
||||||
const usdcMainnetMint = new PublicKey(MAINNET_MINTS.get('USDC')!);
|
const usdcMainnetMint = new PublicKey(MAINNET_MINTS.get('USDC')!);
|
||||||
await client.stubOracleCreate(group, usdcMainnetMint, 1.0);
|
await client.stubOracleCreate(group, usdcMainnetMint, 1.0);
|
||||||
|
@ -69,11 +88,11 @@ async function main() {
|
||||||
0,
|
0,
|
||||||
'USDC',
|
'USDC',
|
||||||
0.004,
|
0.004,
|
||||||
0.4,
|
0.7,
|
||||||
0.07,
|
0.1,
|
||||||
0.8,
|
0.85,
|
||||||
0.9,
|
0.2,
|
||||||
1.5,
|
2.0,
|
||||||
0.005,
|
0.005,
|
||||||
0.0005,
|
0.0005,
|
||||||
1,
|
1,
|
||||||
|
@ -94,18 +113,18 @@ async function main() {
|
||||||
1,
|
1,
|
||||||
'USDT',
|
'USDT',
|
||||||
0.004,
|
0.004,
|
||||||
0.4,
|
0.7,
|
||||||
0.07,
|
0.1,
|
||||||
0.8,
|
0.85,
|
||||||
0.9,
|
0.2,
|
||||||
1.5,
|
2.0,
|
||||||
0.005,
|
0.005,
|
||||||
0.0005,
|
0.0005,
|
||||||
0.95,
|
0.95,
|
||||||
0.9,
|
0.9,
|
||||||
1.05,
|
1.05,
|
||||||
1.1,
|
1.1,
|
||||||
0.02,
|
0.025,
|
||||||
);
|
);
|
||||||
|
|
||||||
console.log(`Registering BTC...`);
|
console.log(`Registering BTC...`);
|
||||||
|
@ -119,11 +138,11 @@ async function main() {
|
||||||
2,
|
2,
|
||||||
'BTC',
|
'BTC',
|
||||||
0.004,
|
0.004,
|
||||||
0.4,
|
0.7,
|
||||||
0.07,
|
0.1,
|
||||||
0.8,
|
0.85,
|
||||||
0.9,
|
0.2,
|
||||||
1.5,
|
2.0,
|
||||||
0.005,
|
0.005,
|
||||||
0.0005,
|
0.0005,
|
||||||
0.9,
|
0.9,
|
||||||
|
@ -144,11 +163,36 @@ async function main() {
|
||||||
3,
|
3,
|
||||||
'ETH',
|
'ETH',
|
||||||
0.004,
|
0.004,
|
||||||
0.4,
|
0.7,
|
||||||
0.07,
|
0.1,
|
||||||
0.8,
|
0.85,
|
||||||
|
0.2,
|
||||||
|
2.0,
|
||||||
|
0.005,
|
||||||
|
0.0005,
|
||||||
0.9,
|
0.9,
|
||||||
1.5,
|
0.8,
|
||||||
|
1.1,
|
||||||
|
1.2,
|
||||||
|
0.05,
|
||||||
|
);
|
||||||
|
|
||||||
|
console.log(`Registering soETH...`);
|
||||||
|
const soEthMainnetMint = new PublicKey(MAINNET_MINTS.get('soETH')!);
|
||||||
|
const soEthMainnetOracle = new PublicKey(MAINNET_ORACLES.get('soETH')!);
|
||||||
|
await client.tokenRegister(
|
||||||
|
group,
|
||||||
|
soEthMainnetMint,
|
||||||
|
soEthMainnetOracle,
|
||||||
|
0.1,
|
||||||
|
4,
|
||||||
|
'soETH',
|
||||||
|
0.004,
|
||||||
|
0.7,
|
||||||
|
0.1,
|
||||||
|
0.85,
|
||||||
|
0.2,
|
||||||
|
2.0,
|
||||||
0.005,
|
0.005,
|
||||||
0.0005,
|
0.0005,
|
||||||
0.9,
|
0.9,
|
||||||
|
@ -166,14 +210,14 @@ async function main() {
|
||||||
solMainnetMint,
|
solMainnetMint,
|
||||||
solMainnetOracle,
|
solMainnetOracle,
|
||||||
0.1,
|
0.1,
|
||||||
4,
|
5,
|
||||||
'SOL',
|
'SOL',
|
||||||
0.004,
|
0.004,
|
||||||
0.4,
|
0.7,
|
||||||
0.07,
|
0.1,
|
||||||
0.8,
|
0.85,
|
||||||
0.9,
|
0.2,
|
||||||
1.5,
|
2.0,
|
||||||
0.005,
|
0.005,
|
||||||
0.0005,
|
0.0005,
|
||||||
0.9,
|
0.9,
|
||||||
|
@ -191,14 +235,14 @@ async function main() {
|
||||||
msolMainnetMint,
|
msolMainnetMint,
|
||||||
msolMainnetOracle,
|
msolMainnetOracle,
|
||||||
0.1,
|
0.1,
|
||||||
5,
|
6,
|
||||||
'MSOL',
|
'MSOL',
|
||||||
0.004,
|
0.004,
|
||||||
0.4,
|
0.7,
|
||||||
0.07,
|
0.1,
|
||||||
0.8,
|
0.85,
|
||||||
0.9,
|
0.2,
|
||||||
1.5,
|
2.0,
|
||||||
0.005,
|
0.005,
|
||||||
0.0005,
|
0.0005,
|
||||||
0.9,
|
0.9,
|
||||||
|
@ -208,25 +252,64 @@ async function main() {
|
||||||
0.05,
|
0.05,
|
||||||
);
|
);
|
||||||
|
|
||||||
console.log(`Registering MNGO...`);
|
|
||||||
await client.groupEdit(group, group.admin, group.admin, undefined, undefined);
|
|
||||||
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
|
// log tokens/banks
|
||||||
await group.reloadAll(client);
|
await group.reloadAll(client);
|
||||||
for (const bank of await group.banksMap.values()) {
|
for (const bank of await group.banksMap.values()) {
|
||||||
console.log(`${bank.toString()}`);
|
console.log(`${bank.toString()}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
process.exit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function createUser() {
|
||||||
|
const options = AnchorProvider.defaultOptions();
|
||||||
|
const connection = new Connection(process.env.CLUSTER_URL!, options);
|
||||||
|
|
||||||
|
const user = Keypair.fromSecretKey(
|
||||||
|
Buffer.from(
|
||||||
|
JSON.parse(fs.readFileSync(process.env.MB_PAYER_KEYPAIR!, 'utf-8')),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
const userWallet = new Wallet(user);
|
||||||
|
const userProvider = new AnchorProvider(connection, userWallet, options);
|
||||||
|
|
||||||
|
const client = await MangoClient.connect(
|
||||||
|
userProvider,
|
||||||
|
'mainnet-beta',
|
||||||
|
MANGO_V4_ID['mainnet-beta'],
|
||||||
|
);
|
||||||
|
|
||||||
|
const admin = Keypair.fromSecretKey(
|
||||||
|
Buffer.from(
|
||||||
|
JSON.parse(fs.readFileSync(process.env.MB_PAYER_KEYPAIR!, 'utf-8')),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
const group = await client.getGroupForCreator(admin.publicKey, 2);
|
||||||
|
console.log(`${group.toString()}`);
|
||||||
|
|
||||||
|
console.log(`Creating MangoAccount...`);
|
||||||
|
const mangoAccount = await client.getOrCreateMangoAccount(
|
||||||
|
group,
|
||||||
|
user.publicKey,
|
||||||
|
);
|
||||||
|
console.log(`...created MangoAccount ${mangoAccount.publicKey.toBase58()}`);
|
||||||
|
console.log(mangoAccount.toString(group));
|
||||||
|
|
||||||
|
await client.tokenDeposit(group, mangoAccount, 'USDC', 10);
|
||||||
|
await mangoAccount.reload(client, group);
|
||||||
|
console.log(`...deposited 10 USDC`);
|
||||||
|
|
||||||
|
await client.tokenDeposit(group, mangoAccount, 'SOL', 1);
|
||||||
|
await mangoAccount.reload(client, group);
|
||||||
|
console.log(`...deposited 1 SOL`);
|
||||||
|
}
|
||||||
|
|
||||||
|
async function main() {
|
||||||
|
await createGroup();
|
||||||
|
await registerTokens();
|
||||||
|
// createUser();
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
main();
|
main();
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
}
|
||||||
|
|
|
@ -36,7 +36,7 @@ async function main() {
|
||||||
console.log(`Admin ${admin.publicKey.toBase58()}`);
|
console.log(`Admin ${admin.publicKey.toBase58()}`);
|
||||||
|
|
||||||
// fetch group
|
// fetch group
|
||||||
const group = await client.getGroupForCreator(admin.publicKey, 0);
|
const group = await client.getGroupForCreator(admin.publicKey, 2);
|
||||||
console.log(`Found group ${group.publicKey.toBase58()}`);
|
console.log(`Found group ${group.publicKey.toBase58()}`);
|
||||||
|
|
||||||
// account
|
// account
|
||||||
|
|
|
@ -29,7 +29,7 @@ async function main() {
|
||||||
);
|
);
|
||||||
console.log(`Admin ${admin.publicKey.toBase58()}`);
|
console.log(`Admin ${admin.publicKey.toBase58()}`);
|
||||||
|
|
||||||
const group = await client.getGroupForCreator(admin.publicKey, 0);
|
const group = await client.getGroupForCreator(admin.publicKey, 2);
|
||||||
console.log(`${group.toString()}`);
|
console.log(`${group.toString()}`);
|
||||||
|
|
||||||
// create + fetch account
|
// create + fetch account
|
||||||
|
|
Loading…
Reference in New Issue