From ad52b5c8d8edae5c53d44868d652520ae8980167 Mon Sep 17 00:00:00 2001
From: Arnau Espin <43625217+aspnxdd@users.noreply.github.com>
Date: Wed, 17 Aug 2022 13:16:19 +0200
Subject: [PATCH] docs: add initial readme (#6)
* feat: add initial readme
* feat: update readme
---
README.md | 1 -
readme.md | 150 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 150 insertions(+), 1 deletion(-)
delete mode 100644 README.md
create mode 100644 readme.md
diff --git a/README.md b/README.md
deleted file mode 100644
index 8ae6686..0000000
--- a/README.md
+++ /dev/null
@@ -1 +0,0 @@
-# candymachine-client-sdk
\ No newline at end of file
diff --git a/readme.md b/readme.md
new file mode 100644
index 0000000..2f436fa
--- /dev/null
+++ b/readme.md
@@ -0,0 +1,150 @@
+# Candymachine Client SDK
+
+
+
+## Pre-alpha version
+
+Candymachine Client SDK is currently under development and in pre-alpha version.
+
+## About The Project
+
+Candymachine Client SDK brings to the table the functions, types and other items from the Candy Machine CLI to be compatible with the browser.
+
+### Features
+
+- Create a Candy Machine V2 with multiple and configurable settings:
+ - Captcha enabled/disabled.
+ - Mutability on the NFTs.
+ - Price, number of NFTs.
+ - Authority.
+ - NFTs hosted on Arweave.
+ - Time and date to start the minting.
+- Update any Candy Machine V2 in which you are the authority and have the cache file.
+- Explore any Candy Machine V2, view the minted NFTs, remaining NFTs to mint...
+- Mint a NFT from the Candy Machine V2.
+- Available on Solana's Mainnet and Devnet networks.
+- Fully compatible with React and NextJS.
+
+### Built with
+
+- Typescript
+- Metaplex
+- Anchor from Serum
+- Solana web3.js
+
+
+
+## Installation
+
+```
+$ npm i @boxfish-studio/candymachine-client-sdk
+$ yarn add @boxfish-studio/candymachine-client-sdk
+$ pnpm add @boxfish-studio/candymachine-client-sdk
+```
+
+
+
+## How to use
+
+### Upload your first Candy Machine
+
+1. Import `uploadV2, loadCandyProgramV2, StorageType, verifyAssets` functions and enums:
+
+```ts
+import { uploadV2, loadCandyProgramV2, StorageType, verifyAssets } from '@boxfish-studio/candymachine-client-sdk'
+
+async function createCandyMachineV2() {
+ let candyMachine: string = ''
+ const config: ICandyMachineConfig = {
+ price: 1,
+ number: 200,
+ gatekeeper: null,
+ solTreasuryAccount: ******************, // where the NFTs initial sale SOL will go to
+ splTokenAccount: null,
+ splToken: null,
+ goLiveDate: "21 Jul 2023 16:00:00 GMT",
+ endSettings: null,
+ whitelistMintSettings: null,
+ hiddenSettings: null,
+ storage: StorageType.Arweave,
+ ipfsInfuraProjectId: null,
+ ipfsInfuraSecret: null,
+ nftStorageKey: null,
+ awsS3Bucket: null,
+ noRetainAuthority: false,
+ noMutable: false,
+ arweaveJwk: null,
+ batchSize: null,
+ pinataGateway: null,
+ pinataJwt: null,
+ uuid: null,
+ }
+ // files being all the assets uploaded to the page: [0.json, 0.png, 1.json, 1.png....]
+ const { supportedFiles, elemCount } = verifyAssets(files, config.storage, config.number)
+
+ const provider = new AnchorProvider(connection, anchorWallet, {
+ preflightCommitment: 'recent',
+ })
+
+ const anchorProgram = await loadCandyProgramV2(provider)
+
+ const {
+ storage,
+ nftStorageKey,
+ ipfsInfuraProjectId,
+ number,
+ ipfsInfuraSecret,
+ pinataJwt,
+ pinataGateway,
+ arweaveJwk,
+ awsS3Bucket,
+ retainAuthority,
+ mutable,
+ batchSize,
+ price,
+ splToken,
+ treasuryWallet,
+ gatekeeper,
+ endSettings,
+ hiddenSettings,
+ whitelistMintSettings,
+ goLiveDate,
+ uuid,
+ } = await getCandyMachineV2Config(publicKey, config, anchorProgram)
+
+ try {
+ const _candyMachine = await uploadV2({
+ files: supportedFiles,
+ cacheName: 'example',
+ env: "devnet",
+ totalNFTs: elemCount,
+ gatekeeper,
+ storage,
+ retainAuthority,
+ mutable,
+ batchSize,
+ price,
+ treasuryWallet,
+ anchorProgram,
+ walletKeyPair: anchorWallet, // from react solana wallet package
+ endSettings,
+ hiddenSettings,
+ whitelistMintSettings,
+ goLiveDate,
+ rateLimit: null,
+ })
+
+ if (typeof _candyMachine === 'string') candyMachine = _candyMachine
+ console.log("Candy machine v2 successfully created!")
+ } catch (err) {
+ console.error("Error during candy machine v2 upload.")
+ }
+
+ }
+
+```
+
+## Acknowledgements
+
+This SDK has been built thanks to Metaplex's Candy Machine CLI.
+