0.4.1 • Published 2 years ago

@metaplex-foundation/beet-solana v0.4.1

Weekly downloads
-
License
Apache-2.0
Repository
github
Last release
2 years ago

@metaplex-foundation/beet-solana

Solana specific extension for beet, the borsh compatible de/serializer

API

Please find the API docs here.

GPA Builders

solana-beet uses beets knowledge about account layouts to provide GpaBuilders for them which allow to filter by account data size and content.

  1. Create a GPA Builder via const gpaBuilder = GpaBuilder.fromStruct(programId, accountStruct)
  2. add filters via gpaBuilder.dataSize, gpaBuilder.addFilter or gpaBuilder.addInnerFilter
  3. execute gpaBuilder.run(connection) which will return all accounts matching the specified filters

Examples

Simple struct with primitives

export type ResultsArgs = Pick<Results, 'win' | 'totalWin' | 'losses'>
export class Results {
  constructor(
    readonly win: number,
    readonly totalWin: number,
    readonly losses: number
  ) {}

  static readonly struct = new BeetStruct<Results, ResultsArgs>(
    [
      ['win', u8],
      ['totalWin', u16],
      ['losses', i32],
    ],
    (args: ResultsArgs) => new Results(args.win!, args.totalWin!, args.losses!),
    'Results'
  )
}

const gpaBuilder = GpaBuilder.fromStruct(PROGRAM_ID, Results.struct)
const accounts = await gpaBuilder
  .addFilter('totalWin', 8)
  .addFilter('losses', -7)
  .run()

Matching on Complete Nested Struct

Using Results struct from above

export type TraderArgs = Pick<Trader, 'name' | 'results' | 'age'>
export class Trader {
  constructor(
    readonly name: string,
    readonly results: Results,
    readonly age: number
  ) {}

  static readonly struct = new BeetStruct<Trader, TraderArgs>(
    [
      ['name', fixedSizeUtf8String(4)],
      ['results', Results.struct],
      ['age', u8],
    ],
    (args) => new Trader(args.name!, args.results!, args.age!),
    'Trader'
  )
}

const gpaBuilder = GpaBuilder.fromStruct<Trader>(
  PROGRAM_ID,
  Trader.struct
)

const results = {
  win: 3,
  totalWin: 4,
  losses: -100,
}

const accounts = await gpaBuilder.addFilter('results', results).run()

Matching on Part of Nested Struct

Using Trader struct from above

const gpaBuilder = GpaBuilder.fromStruct<Trader>(
  PROGRAM_ID,
  Trader.struct
)

const account = await gpaBuilder
  .addInnerFilter('results.totalWin', 8)
  .addInnerFilter('results.win', 2)
  .run()

PublicKey

solana-beet provides a de/serializer for solana public keys. They can either be used directly or as part of a struct.

Examples

Using PublicKey Directly

import { publicKey } from '@metaplex-foundation/beet-solana'

const generatedKey  = Keypair.generate().publicKey
const buf = Buffer.alloc(publicKey.byteSize)
beet.write(buf, 0, generatedKey)
beet.read(buf, 0) // same as generatedKey

PublicKey as part of a Struct Configuration

import * as web3 from '@solana/web3.js'
import * as beet from '@metaplex-foundation/beet'
import * as beetSolana from '@metaplex-foundation/beet-solana'

type InstructionArgs = {
  authority: web3.PublicKey
}

const createStruct = new beet.BeetArgsStruct<InstructionArgs>(
  [
    ['authority', beetSolana.publicKey]
  ],
  'InstructionArgs'
)

LICENSE

Apache-2.0

rainfi-cli-testrainfi-test@flxxyz-foundation/js@holaplex/mpl-listing-rewards@holaplex/mpl-reward-center@layerzerolabs/layerzero-v2-solana-sdk@everything-registry/sub-chunk-597w3poker-solana-nfthydra-sdk-anchorproviderkyzr-auction-house@tumi-labs/liquidprop@tumi-labs/zar@undergroundsociety/raffle@usedispatch/forum_broadcastairmoney-sdkam-other-sdkauction-house-v2@noxal/mpl-auction-house@onsol/tldparser@onsol/tldsolve@phantasia/blockchain-interface@phantasia/nft-store-interface@paystreamfinance/sdkgeist-sdk@squads-protocol/multisig@splitwave/js@sqds/multisig@stakingcapital.io/reward-distributor-sdk@stakingcapital.io/stake-pool-sdkdreader-comic-verseesbonk-stake-sdkexex@2112-labs/emerald-react@2112-labs/emerald.js@0xmukesh/squad-multisig0xppl-solana-portfolio@0xbanana/js@blockpal/vault-x-sdk@blockpal/vault-x-sdk-alpha@cardinal/mpl-candy-machine-utilscc-other-sdkcc-backoffice-sdkcircuscasino-sdkbrick-protocolblob-metadata@appliedblockchain/metaplex-js@agreewe/solana-blockchain-contracts@arrangedev/trusts-sdk@altruism-finance/js@albus-finance/sdk@albus-finance/swap-sdk@avingoyal01/portfolio-plugins@blockpal/guild-vault-sdktoken-metadata-descriptor@agreewe-dev/solana-blockchain-contracts@layerzerolabs/lz-solana-sdk-v2@layerzerolabs/oft-v2-solana-sdk@lorisleiva/mpl-candy-guard@lorisleiva/mpl-candy-machine-core@lorisleiva/mpl-fair-launch@loris-sandbox/mx-monorepo-js@lorisleiva/js-next-alphampl-triflemetapass-sdkmyrandompackagetest7799sequiilloseaway-sdkpixels-on-chain-solanarestake-tsreflect-sdkquisquibusdamsolana-frameworksolaplexsolaplex-foundationsolaplex1soar_sdkglaicon-nft-packs@cryowar/escrow-program-interface@code-wallet/programs@colosseum-so/colosseum-promo-sdk@cosimo-rip/js@faircrypto/multisig@fluidchains/ywpl-token-metadata@fluidchains/ywpl-token-vault@jito-foundation/stake-deposit-interceptor-sdk@solana/spl-account-compression@sol-tools/counter@solanahub/portfolio-plugins@hourglassproto/sdk@guakamoli/js@motleylabs/mtly-auction-house@motleylabs/mtly-reward-center@reclaimprotocol/solana-sdk@reflectcx/delta-neutral@reflectcx/restaking@reflectcx/tokenised-bond@render-foundation/multisig@revibase/multi-wallet@jolders/mpl-auction-house@rainfi/rain
0.4.1

2 years ago

0.4.0

3 years ago

0.3.1

3 years ago

0.3.0

3 years ago

0.2.0

3 years ago

0.1.0

4 years ago

0.1.1

4 years ago

0.0.6

4 years ago

0.0.5

4 years ago

0.0.4

4 years ago

0.0.3

4 years ago

0.0.2

4 years ago

0.0.1

4 years ago

0.0.0

4 years ago