Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/snowflake-so/snowflake-sdk
https://github.com/snowflake-so/snowflake-sdk
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/snowflake-so/snowflake-sdk
- Owner: snowflake-so
- Created: 2022-03-03T04:18:32.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2022-06-09T15:04:29.000Z (over 2 years ago)
- Last Synced: 2024-10-28T22:36:04.516Z (3 months ago)
- Language: TypeScript
- Size: 134 KB
- Stars: 38
- Watchers: 1
- Forks: 6
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome - snowflake-so/snowflake-sdk - (TypeScript)
README
# Snowflake TypeScript SDK
Snowflake SDK provides services and a set of APIs used for interacting with the automation infrastructure of Snowflake on Solana blockchain. Learn more about Snowflake here.
## Installation
Install with npm
```bash
npm i @snowflake-so/snowflake-sdk
```Install with yarn
```bash
yarn add @snowflake-so/snowflake-sdk
```## Quick start guide
### Initialize Snowflake
To create a new Snowflake service, we would need to initialize with the Provider.
```typescript
// if your Anchor version is older than 0.24.2,
// please use Snowflake SDK version 1.0.11 and initialize the provider as below
let provider: Provider = Provider.local(API_URL);// if your Anchor version is 0.24.2 or later,
// please use the latest version of Snowflake SDK and initialize the provider as below
let provider: Provider = AnchorProvider.local(API_URL);
```The `API_URL` is the endpoint to the Solana cluster. Empty API_URL is pointed to the `local testnet`
- Mainnet Beta: `https://api.mainnet-beta.solana.com`
- Testnet: `https://api.testnet.solana.com`
- Devnet: `https://api.devnet.solana.com````typescript
let snowflake: Snowflake = new Snowflake(provider);
```### Build an once-off scheduled job
With Snowflake SDK, you can create a job with two line of code.
```typescript
const job = new JobBuilder()
.jobName("hello world")
.jobInstructions(instructions)
.scheduleOnce(tomorrow())
.build();await snowflake.createJob(job);
```### Build a recurring scheduled job
Schedule a job that runs every minute for 10 times.
```typescript
const job = new JobBuilder()
.jobName("hello world")
.jobInstructions(instructions)
.scheduleCron("* * * * *", 10)
.build();await snowflake.createJob(job);
```Schedule a job that runs at 10:00 AM on the first day of every month .
```typescript
const job = new JobBuilder()
.jobName("hello world")
.jobInstructions(instructions)
.scheduleCron("0 10 1 * *")
.build();await snowflake.createJob(job);
```### Build a program condition triggered job
Schedule a job that is triggered based on an arbitrary condition defined within the user program.
```typescript
const job = new JobBuilder()
.jobName("hello world")
.jobInstructions(instructions)
.scheduleConditional(1)
.build();await snowflake.createJob(job);
```### Build a self-funded job
Self-funded job will take an account to pay fees on its own by using the initial fund. Fee account is no longer used for paying the job's fee.
```typescript
const job = new JobBuilder()
.jobName("hello world")
.jobInstruction(instructions)
.scheduleConditional(1);
.selfFunded(true)
.initialFund(100000) // 1000000 lamports
.build()await snowflake.createJob(job)
```### Update a job
```typescript
await snowflake.updateJob(jobPubkey);
```### Delete a job
```typescript
await snowflake.deleteJob(jobPubkey);
```### Fetch Job by public key
```typescript
await snowflake.fetch(jobPubkey);
```### Fetch Job by owner
```typescript
await snowflake.fetchByOwner(owner);
```### Get Snowflake PDA
```typescript
await snowflake.getSnowflakePDAForUser(userPublicKey);
```### Deposit fee account
```typescript
await snowflake.depositFeeAccount(lamports);
```## Usage
```typescript
import { JobBuilder, Snowflake } from "@snowflake-so/snowflake-sdk";
import { Provider } from "@project-serum/anchor";/** Initialize a Snowflake service on Devnet **/
const API_URL: string = "https://api.devnet.solana.com";
const provider: Provider = new Provider(API_URL);
const snowflake: Snowflake = new Snowflake();async function main() {
/** Create a sample instruction **/
const instructions = [
{
programId: new PublicKey("ETwBdF9X2eABzmKmpT3ZFYyUtmve7UWWgzbERAyd4gAC"),
data: Buffer.from("74b89fceb3e0b22a", "hex"),
keys: [
{
pubkey: new PublicKey("5jo4Lh2Z9FGQ87sDhUBwZjNZdL15MwdeT5WUXKfwFSZY"),
isSigner: false,
isWritable: false,
},
],
},
];/** Create a new once-off scheduled job **/
const onceOffJob = new JobBuilder()
.jobName("once-off job")
.jobInstructions(instructions)
.scheduleOnce(1646034062)
// Timestamp: Monday, 28-Feb-22 07:41:02 UTC
.build();const onceOffJobTxID = await snowflake.createJob(onceOffJob);
console.log("Create a recurring job with txId: " + onceOffJobTxID);/** Create a new recurring scheduled job **/
const recurringJob = new JobBuilder()
.jobName("recurring job")
.jobInstruction(instructions)
.scheduleCron("* * * * *")
// Every minute
.build();const recurringJobTxID = await snowflake.createJob(recurringJob);
console.log("Create a recurring job with txId: " + recurringJobTxID);/** Fetch an once-off job **/
const fetchedOnceOffJob = await snowflake.fetch(onceOffJob.pubkey);// Build from an existing job
const updatedJob = new JobBuilder()
.fromExistingJob(fetchedOnceOffJob)
.jobName("hello world 2")
.scheduleCron("0 * * * *", 2)
.build();/** Update a job **/
await snowflake.updateJob(updatedJob);/** Delete a job **/
await snowflake.deleteJob(job.pubKey);/** Get Snowflake PDA for user **/
const walletAddress: PublicKey = provider.wallet.publicKey;
await snowflake.getSnowflakePDAforUser(walletAddress);/** Deposit to fee account (5000000 lamports) **/
await snowflake.depositFeeAccount(5000000);
}
```## Support
**Struggle with the SDK integration?**
If you have any problem with using the SDK in your system, drop a question our Snowflake Discord `#sdk` to receive a support from our engineers.
**Find a bug? Find a new idea for Snowflake?**
If you find a bug or have any problem and idea while using the SDK, you can create an issue on Snowflake SDK Github.
## License
MIT