jackal.js docs expansion
This commit is contained in:
parent
18d406cff8
commit
1b87376173
8
.idea/.gitignore
vendored
Normal file
8
.idea/.gitignore
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# Default ignored files
|
||||||
|
/shelf/
|
||||||
|
/workspace.xml
|
||||||
|
# Editor-based HTTP Client requests
|
||||||
|
/httpRequests/
|
||||||
|
# Datasource local storage ignored files
|
||||||
|
/dataSources/
|
||||||
|
/dataSources.local.xml
|
9
.idea/canine-docs.iml
Normal file
9
.idea/canine-docs.iml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<module type="JAVA_MODULE" version="4">
|
||||||
|
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||||
|
<exclude-output />
|
||||||
|
<content url="file://$MODULE_DIR$" />
|
||||||
|
<orderEntry type="inheritedJdk" />
|
||||||
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
|
</component>
|
||||||
|
</module>
|
6
.idea/misc.xml
Normal file
6
.idea/misc.xml
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectRootManager">
|
||||||
|
<output url="file://$PROJECT_DIR$/out" />
|
||||||
|
</component>
|
||||||
|
</project>
|
8
.idea/modules.xml
Normal file
8
.idea/modules.xml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectModuleManager">
|
||||||
|
<modules>
|
||||||
|
<module fileurl="file://$PROJECT_DIR$/.idea/canine-docs.iml" filepath="$PROJECT_DIR$/.idea/canine-docs.iml" />
|
||||||
|
</modules>
|
||||||
|
</component>
|
||||||
|
</project>
|
6
.idea/vcs.xml
Normal file
6
.idea/vcs.xml
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="VcsDirectoryMappings">
|
||||||
|
<mapping directory="" vcs="Git" />
|
||||||
|
</component>
|
||||||
|
</project>
|
@ -9,19 +9,32 @@ To get started using Jackal in the browser, you'll need a few things!
|
|||||||
|
|
||||||
### Pre-requesites
|
### Pre-requesites
|
||||||
|
|
||||||
* [Node.js](https://nodejs.org/en/download)
|
* [Vue.js](https://vuejs.org/guide/introduction.html) or [React](https://react.dev/learn)
|
||||||
* [Jackal.js](https://www.npmjs.com/package/jackal.js)
|
* [Jackal.js](https://www.npmjs.com/package/jackal.js)
|
||||||
* [Vite](https://vitejs.dev/)
|
* [Vite](https://vitejs.dev)
|
||||||
* [Keplr](https://www.keplr.app/)
|
* Chromium-family browser (Chrome, Brave, Edge, etc)
|
||||||
|
* [Keplr](https://www.keplr.app) or [Leap](https://www.leapwallet.io/cosmos) wallet extension
|
||||||
|
|
||||||
### Setting Up
|
### Setting Up
|
||||||
|
|
||||||
To get started, make sure you start your project using Vite. If you have an existing React app for example, re-init the project using Vite.
|
To get started, make sure you [start your project using Vite](https://vitejs.dev/guide). If you have an existing React app for example, re-init the project using Vite.
|
||||||
|
|
||||||
|
Install dependencies:
|
||||||
|
```shell
|
||||||
|
npm install jackal.js
|
||||||
|
npm install -D vite-plugin-node-stdlib-browser
|
||||||
|
```
|
||||||
|
|
||||||
|
Jackal.js requires Node v20+. The easiest way to manage this is with [NVM](https://github.com/nvm-sh/nvm#installing-and-updating).
|
||||||
|
```shell
|
||||||
|
nvm use 20
|
||||||
|
```
|
||||||
|
|
||||||
#### Updating Vite Config
|
#### Updating Vite Config
|
||||||
|
|
||||||
```js
|
```js
|
||||||
// In vite.config.js:
|
// In vite.config.js:
|
||||||
|
import { defineConfig } from 'vite'
|
||||||
import nodePolyfills from 'vite-plugin-node-stdlib-browser'
|
import nodePolyfills from 'vite-plugin-node-stdlib-browser'
|
||||||
|
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
@ -33,10 +46,82 @@ export default defineConfig({
|
|||||||
|
|
||||||
### Connecting Your Wallet
|
### Connecting Your Wallet
|
||||||
|
|
||||||
|
Custom chain configurations are required for [Testnet](#testnet-configuration), and for Keplr on [Mainnet](#mainnet-configuration). The following are the correct options to use.
|
||||||
|
Jackal.js additionally supports app-level overrides to the chain default settings. This requires some redundancy, but allows for greater flexibility in projects.
|
||||||
|
|
||||||
|
#### Wallet Selection
|
||||||
|
|
||||||
|
Currently Jackal,js supports Keplr and Leap wallets. Only a single wallet can be used at any time, but you can switch between them as desired.
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const chainConfig = { // mainnet chain config
|
const selectedWallet = 'keplr'
|
||||||
|
// OR
|
||||||
|
const selectedWallet = 'leap'
|
||||||
|
```
|
||||||
|
|
||||||
|
#### <a name="testnet-configuration"></a>Testnet Configuration
|
||||||
|
|
||||||
|
```js
|
||||||
|
const chainConfig = {
|
||||||
|
chainId: 'lupulella-2',
|
||||||
|
chainName: 'Jackal Testnet II',
|
||||||
|
rpc: 'https://testnet-rpc.jackalprotocol.com',
|
||||||
|
rest: 'https://testnet-api.jackalprotocol.com',
|
||||||
|
bip44: {
|
||||||
|
coinType: 118
|
||||||
|
},
|
||||||
|
coinType: 118,
|
||||||
|
stakeCurrency: {
|
||||||
|
coinDenom: 'JKL',
|
||||||
|
coinMinimalDenom: 'ujkl',
|
||||||
|
coinDecimals: 6
|
||||||
|
},
|
||||||
|
bech32Config: {
|
||||||
|
bech32PrefixAccAddr: 'jkl',
|
||||||
|
bech32PrefixAccPub: 'jklpub',
|
||||||
|
bech32PrefixValAddr: 'jklvaloper',
|
||||||
|
bech32PrefixValPub: 'jklvaloperpub',
|
||||||
|
bech32PrefixConsAddr: 'jklvalcons',
|
||||||
|
bech32PrefixConsPub: 'jklvalconspub'
|
||||||
|
},
|
||||||
|
currencies: [
|
||||||
|
{
|
||||||
|
coinDenom: 'JKL',
|
||||||
|
coinMinimalDenom: 'ujkl',
|
||||||
|
coinDecimals: 6
|
||||||
|
}
|
||||||
|
],
|
||||||
|
feeCurrencies: [
|
||||||
|
{
|
||||||
|
coinDenom: 'JKL',
|
||||||
|
coinMinimalDenom: 'ujkl',
|
||||||
|
coinDecimals: 6,
|
||||||
|
gasPriceStep: {
|
||||||
|
low: 0.002,
|
||||||
|
average: 0.002,
|
||||||
|
high: 0.02
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
features: []
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
```js
|
||||||
|
const appConfig = {
|
||||||
|
signerChain: 'lupulella-2',
|
||||||
|
enabledChains: ['lupulella-2'],
|
||||||
|
queryAddr: 'https://testnet-grpc.jackalprotocol.com',
|
||||||
|
txAddr: 'https://testnet-rpc.jackalprotocol.com'
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### <a name="mainnet-configuration"></a>Mainnet Configuration
|
||||||
|
|
||||||
|
```js
|
||||||
|
const chainConfig = {
|
||||||
chainId: 'jackal-1',
|
chainId: 'jackal-1',
|
||||||
chainName: 'Jackal',
|
chainName: 'Jackal Mainnet',
|
||||||
rpc: 'https://rpc.jackalprotocol.com',
|
rpc: 'https://rpc.jackalprotocol.com',
|
||||||
rest: 'https://api.jackalprotocol.com',
|
rest: 'https://api.jackalprotocol.com',
|
||||||
bip44: {
|
bip44: {
|
||||||
@ -77,71 +162,100 @@ const chainConfig = { // mainnet chain config
|
|||||||
],
|
],
|
||||||
features: []
|
features: []
|
||||||
}
|
}
|
||||||
|
```
|
||||||
|
|
||||||
const walletConfig = {
|
```js
|
||||||
selectedWallet: 'keplr',
|
const appConfig = {
|
||||||
signerChain: 'jackal-1',
|
signerChain: 'jackal-1',
|
||||||
enabledChains: ['jackal-1'],
|
enabledChains: ['jackal-1'],
|
||||||
queryAddr: 'https://grpc.jackalprotocol.com',
|
queryAddr: 'https://grpc.jackalprotocol.com',
|
||||||
txAddr: 'https://rpc.jackalprotocol.com',
|
txAddr: 'https://rpc.jackalprotocol.com'
|
||||||
chainConfig: chainConfig
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Bringing the full config together
|
||||||
|
|
||||||
|
```js
|
||||||
|
const finalWalletConfig = {
|
||||||
|
selectedWallet,
|
||||||
|
...appConfig,
|
||||||
|
chainConfig
|
||||||
}
|
}
|
||||||
|
|
||||||
// Hooking up the wallet to your app
|
// Hooking up the wallet to your app
|
||||||
const wallet = await WalletHandler.trackWallet(walletConfig)
|
const wallet = await WalletHandler.trackWallet(finalWalletConfig)
|
||||||
|
```
|
||||||
|
|
||||||
|
Additionally, a query-only mode for the wallet can get accessed via the following:
|
||||||
|
|
||||||
|
```js
|
||||||
|
const wallet = await WalletHandler.trackQueryWallet('https://grpc.jackalprotocol.com') // Use the gRPC-web address of your choice
|
||||||
```
|
```
|
||||||
|
|
||||||
### Buying Storage Space
|
### Buying Storage Space
|
||||||
|
|
||||||
Every account that wishes to use the Jackal Protocol to store data needs to have a paid account. This means giving the protocol $8/month/tb. We can do this with Jackal.js!
|
Every account that wishes to use the Jackal Protocol to store data needs to have a paid storage account.
|
||||||
|
This means giving the protocol $8 USD per month per tb. We can do this with Jackal.js!
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const storage = await StorageHandler.trackStorage(wallet)
|
const storage = await StorageHandler.trackStorage(wallet)
|
||||||
|
|
||||||
// (Wallet address, duration in hours (min 720),
|
// (Wallet address, duration in months (min 1),
|
||||||
// space in bytes (min 1000000000)
|
// space in terabytes (min .001)
|
||||||
await storage.buyStorage(WALLET_ADDRESS, 720, 1000000000000)
|
|
||||||
|
// 2 TB for 1 year:
|
||||||
|
await storage.buyStorage(WALLET_ADDRESS, 12, 2)
|
||||||
```
|
```
|
||||||
|
|
||||||
### Creating a Folder
|
### Creating a Root Folder
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const fileIo = await FileIo.trackIo(wallet)
|
const fileIo = await FileIo.trackIo(wallet)
|
||||||
|
|
||||||
const listOfFolders = ["folder_name", ...]
|
const listOfRootFolders = ["Home", ...]
|
||||||
// you can create as many folders as you would like this way
|
// you can create as many root folders as you would like this way. Home is the dashboard default root directory.
|
||||||
|
|
||||||
// The first time a user connects, they must init the system
|
// The first time a user connects, they must init the system
|
||||||
const storage = await StorageHandler.trackStorage(wallet)
|
const storage = await StorageHandler.trackStorage(wallet)
|
||||||
const msg = storage.makeStorageInitMsg()
|
const msg = storage.makeStorageInitMsg()
|
||||||
await fileIo.generateInitialDirs(msg, listOfFolders)
|
await fileIo.generateInitialDirs(msg, listOfRootFolders)
|
||||||
|
|
||||||
// after the first time, this code can be used instead. this will only create new folders if they don't already exist
|
// after the first time, this code can be used instead. this will only create new root folders if they don't already exist
|
||||||
const newFolderCount = await fileIo.verifyFoldersExist(listOfFolders)
|
const newFolderCount = await fileIo.verifyFoldersExist(listOfRootFolders)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Creating a Child Folder
|
||||||
|
|
||||||
|
```js
|
||||||
|
const fileIo = await FileIo.trackIo(wallet)
|
||||||
|
|
||||||
|
const parentFolderPath = PARENT_FOLDER_NAME // for example Dashboard's root folder path is s/Home
|
||||||
|
const parent = await fileIo.downloadFolder(parentFolderPath)
|
||||||
|
|
||||||
|
const listOfChildFolders = ["Movies", "Pictures", ...]
|
||||||
|
|
||||||
|
await fileIo.createFolders(parent, listOfChildFolders)
|
||||||
|
```
|
||||||
|
|
||||||
### Uploading a File
|
### Uploading a File
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const fileIo = await FileIo.trackIo(wallet)
|
const fileIo = await FileIo.trackIo(wallet)
|
||||||
|
|
||||||
const parentFolderPath = PARENT_FOLDER_NAME // replace this with your own path
|
const parentFolderPath = PARENT_FOLDER_NAME // for example Dashboard's root folder path is s/Home
|
||||||
const fileName = FILE_NAME // replace this with your own file name
|
|
||||||
|
|
||||||
const handler = await FileUploadHandler.trackFile(FILE_OBJECT, parentFolderPath)
|
|
||||||
|
|
||||||
const parent = await fileIo.downloadFolder(parentFolderPath)
|
const parent = await fileIo.downloadFolder(parentFolderPath)
|
||||||
|
|
||||||
const uploadList = {
|
const file = FILE_OBJECT // this MUST be an instance of File() that is in the browser memory
|
||||||
fileName: {
|
const fileName = file.name
|
||||||
|
const handler = await FileUploadHandler.trackFile(file, parentFolderPath)
|
||||||
|
|
||||||
|
const uploadList = {}
|
||||||
|
uploadList[fileName] = {
|
||||||
data: null,
|
data: null,
|
||||||
exists: false,
|
exists: false,
|
||||||
handler: handler,
|
handler: handler,
|
||||||
key: fileName,
|
key: fileName,
|
||||||
uploadable: await handler.getForUpload()
|
uploadable: await handler.getForUpload()
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
await fileIo.staggeredUploadFiles(uploadList, parent, {counter: 0, complete: 0})
|
await fileIo.staggeredUploadFiles(uploadList, parent, {counter: 0, complete: 0})
|
||||||
@ -152,17 +266,21 @@ await fileIo.staggeredUploadFiles(uploadList, parent, {counter: 0, complete: 0})
|
|||||||
```js
|
```js
|
||||||
const fileIo = await FileIo.trackIo(wallet)
|
const fileIo = await FileIo.trackIo(wallet)
|
||||||
|
|
||||||
const file = await fileIo.downloadFile(
|
/* optional */
|
||||||
{
|
const parentFolderPath = PARENT_FOLDER_NAME // for example Dashboard's root folder path is s/Home
|
||||||
rawPath: FILE_PATH
|
const parent = await fileIo.downloadFolder(parentFolderPath)
|
||||||
owner: OWNER_ADDRESS
|
const childrenFiles = parent.getChildFiles()
|
||||||
isFolder: false
|
const pathOfFirstChild = parent.getMyChildPath(childrenFiles[0].name)
|
||||||
},
|
/* end optional */
|
||||||
{
|
|
||||||
track: 0
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
const fileData = file.receiveBacon()
|
const downloadDetails = {
|
||||||
|
rawPath: FILE_PATH, // manual complete file path OR pathOfFirstChild
|
||||||
|
owner: OWNER_ADDRESS, // JKL address of file owner
|
||||||
|
isFolder: false
|
||||||
|
}
|
||||||
|
|
||||||
|
const fileHanlder = await fileIo.downloadFile(downloadDetails, { track: 0 })
|
||||||
|
|
||||||
|
const file = fileHanlder.receiveBacon()
|
||||||
// do what you want with the File object returned by receiveBacon
|
// do what you want with the File object returned by receiveBacon
|
||||||
```
|
```
|
Loading…
Reference in New Issue
Block a user