sbv2-solana/javascript/solana.js
Conner Gallagher 16a8b16f39 solana.js: oracle create packing 2022-12-12 16:26:18 -07:00
..
src solana.js: oracle create packing 2022-12-12 16:26:18 -07:00
test solana.js: oracle create packing 2022-12-12 16:26:18 -07:00
.editorconfig added solana.js 2022-11-28 16:50:18 -07:00
.eslintignore added solana.js 2022-11-28 16:50:18 -07:00
.eslintrc.json added solana.js 2022-11-28 16:50:18 -07:00
.gitignore solana.js: added SwitchboardTestContext tests 2022-12-08 12:26:00 -07:00
.prettierrc.js added solana.js 2022-11-28 16:50:18 -07:00
README.md solana.js: README 2022-12-01 21:39:31 -07:00
generate-client.js doc comments 2022-11-30 21:02:57 -07:00
package-lock.json solana.js: published 2.0.44 2022-12-12 11:13:59 -07:00
package.json solana.js: published 2.0.44 2022-12-12 11:13:59 -07:00
tsconfig.base.json added solana.js 2022-11-28 16:50:18 -07:00
tsconfig.cjs.json added solana.js 2022-11-28 16:50:18 -07:00
tsconfig.json added solana.js 2022-11-28 16:50:18 -07:00

README.md

Switchboard Solana SDK

A library of utility functions to interact with Switchboard v2 on Solana.

Official Documentation: https://docs.switchboard.xyz/solana

Typedocs: https://docs.switchboard.xyz/api/@switchboard-xyz/solana.js

Install

npm i --save @switchboard-xyz/solana.js

Usage

Load the Switchboard Program

import { Connection } from '@solana/web3.js';
import {
  SwitchboardProgram,
  TransactionObject,
} from '@switchboard-xyz/solana.js';

const program = await SwitchboardProgram.load(
  'mainnet-beta',
  new Connection('https://api.mainnet-beta.solana.com'),
  payerKeypair /** Optional, READ-ONLY if not provided */
);

Create a queue

import { QueueAccount } from '@switchboard-xyz/solana.js';

const [queueAccount, txnSignature] = await QueueAccount.create(program, {
  name: 'My Queue',
  metadata: 'Top Secret',
  queueSize: 100,
  reward: 0.00001337,
  minStake: 10,
  oracleTimeout: 60,
  slashingEnabled: false,
  unpermissionedFeeds: true,
  unpermissionedVrf: true,
  enableBufferRelayers: false,
});
const queue = await queueAccount.loadData();

Add an oracle

import { QueueAccount } from '@switchboard-xyz/solana.js';

const queueAccount = new QueueAccount(program, queuePubkey);

const [oracleAccount, oracleInitSignature] = await queueAccount.createOracle({
  name: 'My Oracle',
  metadata: 'Oracle #1',
  stakeAmount: 10,
});
const oracle = await oracleAccount.loadData();

await oracleAccount.heartbeat();

Add a data feed

import { QueueAccount } from '@switchboard-xyz/solana.js';

const queueAccount = new QueueAccount(program, queuePubkey);

const [aggregatorAccount, aggregatorInitSignatures] =
  await queueAccount.createFeed({
    batchSize: 1,
    minRequiredOracleResults: 1,
    minRequiredJobResults: 1,
    minUpdateDelaySeconds: 60,
    fundAmount: 2.5, // deposit 2.5 wSOL into the leaseAccount escrow
    jobs: [
      { pubkey: jobAccount.publicKey },
      {
        weight: 2,
        data: OracleJob.encodeDelimited(
          OracleJob.fromObject({
            tasks: [
              {
                valueTask: {
                  value: 1,
                },
              },
            ],
          })
        ).finish(),
      },
    ],
  });
const aggregator = await aggregatorAccount.loadData();

Request a new value

import { AggregatorAccount } from '@switchboard-xyz/solana.js';

const aggregatorAccount = new AggregatorAccount(program, aggregatorPubkey);

await aggregatorAccount.openRound();

After the oracles respond, read the feed result

import Big from 'big.js';
import { AggregatorAccount } from '@switchboard-xyz/solana.js';

const aggregatorAccount = new AggregatorAccount(program, aggregatorPubkey);

const result: Big | null = await aggregatorAccount.fetchLatestValue();
if (result === null) {
  throw new Error('Aggregator holds no value');
}
console.log(result.toString());

Optionally, add a history buffer to your feed to store the last N historical samples

import {
  AggregatorAccount,
  AggregatorHistoryBuffer,
} from '@switchboard-xyz/solana.js';

const aggregatorAccount = new AggregatorAccount(program, aggregatorPubkey);
const aggregator = await aggregatorAccount.loadData();

const [historyBuffer, addHistorySignature] =
  await AggregatorHistoryBuffer.create(program, {
    aggregatorAccount,
    maxSamples: 10000,
  });
const history = await historyBuffer.loadData();

Setup a websocket listener to invoke a callback whenever an aggregator is updated

import Big from 'big.js';
import { AggregatorAccount } from '@switchboard-xyz/solana.js';

const aggregatorAccount = new AggregatorAccount(program, aggregatorPubkey);

const ws = aggregatorAccount.onChange(aggregator => {
  const result = AggregatorAccount.decodeLatestValue(aggregator);
  if (result !== null) {
    console.log(result.toString());
  }
});