Socket
Socket
Sign inDemoInstall

@skeet-framework/api-plugin-solana-transfer

Package Overview
Dependencies
410
Maintainers
2
Versions
11
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    @skeet-framework/api-plugin-solana-transfer

Skeet API Plugin - Solana Transfer


Version published
Weekly downloads
0
Maintainers
2
Created
Weekly downloads
 

Readme

Source
Skeet Framework Logo

Follow @ELSOUL_LABO2

Skeet API Plugin - Solana Transfer

The Skeet Worker Solana Transfer plugin consists of two primary functions:

  • skeetSolTransfer

  • skeetSplTransfer

Skeet Solana Transfer container will be automatically deployed on Google Cloud by Skeet CLI. Skeet API executes Google Cloud Tasks to run Skeet Worker.

Install

Add Skeet Worker Plugin

$ skeet add workerPlugin
? Select Services to deploy (Use arrow keys)
   = Plugins =
❯ solana-transfer
  orca-swap
  jupiter-swap

Select solana-transfer

Add Plugin

$ skeet add yarn -p @skeet-framework/api-plugin-solana-transfer

Usage

Send Sol

import { generateIv } from '@/lib/crypto'
import { genKeypair, getKeypairData } from '@/lib/solanaUtils'
import {
  skeetSolTransfer,
  SkeetSolTransferParam,
} from '@skeet-framework/api-plugin-solana-transfer'

const queueId = 1 // optional
const fromKeypair = await genKeypair()
const toKeypair = await genKeypair()
const keypairData = await getKeypairData(fromKeypair)
const iv = await generateIv() // decrypt key for worker
const rpcUrl = 'https://api.devnet.solana.com/'
const encodedFromSecretKeyString = await decrypt(
  keypairData.unit8Array.join(','),
  iv
)

const transferSol = async () => {
  const skeetSolTransferParam: SkeetSolTransferParam = {
    id: queueId,
    toAddressPubkey: toKeypair.pubkey.toBase58(),
    transferAmountLamport: 1000,
    encodedFromSecretKeyString,
    iv: iv.toString('base64'),
    rpcUrl,
  }
  await skeetSolTransfer(skeetSolTransferParam)
}

transferSol()

Send SPL Token

import { generateIv } from '@/lib/crypto'
import { genKeypair, getKeypairData } from '@/lib/solanaUtils'
import {
  skeetSplTransfer,
  SkeetSplTransferParam,
} from '@skeet-framework/api-plugin-solana-transfer'

const queueId = 1 // optional
// e.g. $EPCT - https://solscan.io/token/CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP
const TOKEN_MINT_ADDRESS = 'CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP'
const decimal = 6 // TOKEN_MINT_ADDRESS's decimal
const fromKeypair = await genKeypair()
const toKeypair = await genKeypair()
const keypairData = await getKeypairData(fromKeypair)
const iv = await generateIv() // decrypt key for worker
const rpcUrl = 'https://api.mainnet-beta.solana.com/'
const encodedFromSecretKeyString = await decrypt(
  keypairData.unit8Array.join(','),
  iv
)
const transferSpl = async () => {
  const skeetSplTransferParam: SkeetSplTransferParam = {
    id: queueId,
    toAddressPubkey: toKeypair.pubkey.toBase58(),
    tokenMintAddress: TOKEN_MINT_ADDRESS,
    transferAmountLamport: 1000,
    encodedFromSecretKeyString,
    iv: iv.toString('base64'),
    rpcUrl,
    decimal,
  }
  await skeetSplTransfer(skeetSolTransferParam)
}
transferSpl()

Skeet Document

Skeet TypeScript Serverless Framework

Nexus Prisma, GraphQL, Relay Connection, ApolloServer with Express, TypeScript, PostgreSQL, Jest Test, Google Cloud Run

What's Skeet?

TypeScript Serverless Framework 'Skeet'.

The Skeet project was launched with the goal of reducing software development, operation, and maintenance costs.

Build Serverless Apps faster. Powered by TypeScript GraphQL, Prisma, Jest, Prettier, and Google Cloud.

Dependency

$ npm i -g skeet
$ skeet create web-app

Skeet Create

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/elsoul/skeet This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

The package is available as open source under the terms of the Apache-2.0 License.

Code of Conduct

Everyone interacting in the SKEET project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.

Keywords

FAQs

Last updated on 23 Mar 2023

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc