fix package.json targets
Signed-off-by: microwavedcola1 <microwavedcola@gmail.com>
This commit is contained in:
parent
921dd8e0a6
commit
ed312e71d5
|
@ -8,7 +8,8 @@
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "tsc",
|
"build": "tsc",
|
||||||
"clean": "rm -rf dist",
|
"clean": "rm -rf dist",
|
||||||
"example": "ts-node ts/example.ts",
|
"example0": "ts-node ts/example0.ts",
|
||||||
|
"example1": "ts-node ts/example1.ts",
|
||||||
"format": "prettier --check .",
|
"format": "prettier --check .",
|
||||||
"lint": "eslint . --ext ts --ext tsx --ext js --quiet",
|
"lint": "eslint . --ext ts --ext tsx --ext js --quiet",
|
||||||
"type-check": "tsc --pretty --noEmit"
|
"type-check": "tsc --pretty --noEmit"
|
||||||
|
|
|
@ -3,6 +3,7 @@ import {
|
||||||
Transaction,
|
Transaction,
|
||||||
TransactionInstruction,
|
TransactionInstruction,
|
||||||
} from '@solana/web3.js';
|
} from '@solana/web3.js';
|
||||||
|
import { assert } from 'console';
|
||||||
import { MangoClient } from '../../client';
|
import { MangoClient } from '../../client';
|
||||||
|
|
||||||
export class Group {
|
export class Group {
|
||||||
|
@ -39,8 +40,8 @@ export async function createGroupIx(
|
||||||
export async function getGroupForAdmin(
|
export async function getGroupForAdmin(
|
||||||
client: MangoClient,
|
client: MangoClient,
|
||||||
adminPk: PublicKey,
|
adminPk: PublicKey,
|
||||||
): Promise<Group[]> {
|
): Promise<Group> {
|
||||||
return (
|
const groups = (
|
||||||
await client.program.account.group.all([
|
await client.program.account.group.all([
|
||||||
{
|
{
|
||||||
memcmp: {
|
memcmp: {
|
||||||
|
@ -50,4 +51,8 @@ export async function getGroupForAdmin(
|
||||||
},
|
},
|
||||||
])
|
])
|
||||||
).map((tuple) => Group.from(tuple.publicKey, tuple.account));
|
).map((tuple) => Group.from(tuple.publicKey, tuple.account));
|
||||||
|
|
||||||
|
assert(groups.length == 1);
|
||||||
|
|
||||||
|
return groups[0];
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import { Program, Provider } from '@project-serum/anchor';
|
import { Program, Provider } from '@project-serum/anchor';
|
||||||
import { PublicKey } from '@solana/web3.js';
|
import { PublicKey } from '@solana/web3.js';
|
||||||
|
import { getGroupForAdmin, Group } from './accounts/types/group';
|
||||||
import { IDL, MangoV4 } from './mango_v4';
|
import { IDL, MangoV4 } from './mango_v4';
|
||||||
|
|
||||||
export const MANGO_V4_ID = new PublicKey(
|
export const MANGO_V4_ID = new PublicKey(
|
||||||
|
@ -47,4 +48,10 @@ export class MangoClient {
|
||||||
devnet,
|
devnet,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public getGroup(adminPk: PublicKey): Promise<Group> {
|
||||||
|
return getGroupForAdmin(this, adminPk);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
import { Provider, Wallet } from '@project-serum/anchor';
|
||||||
|
import { Connection, Keypair, PublicKey } from '@solana/web3.js';
|
||||||
|
import fs from 'fs';
|
||||||
|
import { MangoClient } from './client';
|
||||||
|
|
||||||
|
//
|
||||||
|
// An example based on high level api i.e. the client
|
||||||
|
//
|
||||||
|
async function main() {
|
||||||
|
const options = Provider.defaultOptions();
|
||||||
|
const connection = new Connection(
|
||||||
|
'https://mango.devnet.rpcpool.com',
|
||||||
|
options,
|
||||||
|
);
|
||||||
|
|
||||||
|
const user = Keypair.fromSecretKey(
|
||||||
|
Buffer.from(
|
||||||
|
JSON.parse(fs.readFileSync(process.env.USER_KEYPAIR!, 'utf-8')),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
const userWallet = new Wallet(user);
|
||||||
|
const userProvider = new Provider(connection, userWallet, options);
|
||||||
|
const client = await MangoClient.connect(userProvider, true);
|
||||||
|
console.log(`User ${userWallet.publicKey.toBase58()}`);
|
||||||
|
|
||||||
|
const group = await client.getGroup(
|
||||||
|
new PublicKey('6ACH752p6FsdLzuociVkmDwc3wJW8pcCoxZKfXJKfKcD'),
|
||||||
|
);
|
||||||
|
console.log(group);
|
||||||
|
}
|
||||||
|
|
||||||
|
main();
|
Loading…
Reference in New Issue