Charged Particles
  • What is Charged Particles
  • GETTING STARTED
    • Quick Start
  • CHARGED PARTICLES PROTOCOL
    • Protocol Overview
      • How It Works
      • Current Status
      • Protocol Revenue
      • Protocol Features
    • Why Use Charged Particles?
      • NFT Platforms And How They Differ
      • Charged Particles NFTs - What Are They?
    • How to Use Charged Particles
      • Minting an NFT
      • Energizing an NFT
      • Manage an NFT
      • Using A Test Network
      • Migrating Particles from V1 to V2
    • Developer Docs
      • System Overview
      • Quickstart
        • Read and Write to Contracts
        • Read from the Subgraph
        • Get Kovan ETH + ERC20s
        • VSCode Node.js Typescript Debugging
      • Smart Contracts
        • V2
          • Charged Particles Contract (V2)
          • Charged Settings Contract (V2)
          • Charged State Contract (V2)
          • ProtonB Contract
        • V1
          • Charged Particles Contract
          • Charged Settings Contract
          • Charged State Contract
          • Proton Contract
        • Error Codes
      • Protocol Subgraph
    • IONX
      • IONX Token Addresses
      • IONX Rewards
    • Web3 Packs
    • Liquidity Mining
      • Base Reward Program
      • Leptons
    • Protocol Governance
      • Governance Process
      • Creating a Proposal
      • Voting
      • Delegating Votes
    • Projects + Use Cases
    • Allowlist Application
    • Team
    • Guilds
    • Roadmap
    • Hackathons
      • Hackathon Ideas
      • Previous Hackathons
    • Dune Analytics
  • SDK
    • Charged Particles SDK Overview
    • Quick Start
    • API
    • Advanced Use
    • Types
    • Common Issues / FAQ
    • Common Terminology
  • RESOURCES
    • Hiring!
      • Full-stack/Back-end Web3 Engineer
      • Create Your Own Position
    • Glossary of Terms
    • FAQs
      • Protocol and app.charged.fi
      • Governance
      • Other
      • How to report a bug
    • External Contracts Allowlisted
    • Audits
    • Legal
      • Beta End User License Agreement (EULA)
      • Privacy Policy
      • Policies & Terms of Service
    • Media Kit
  • Additional Resources
    • Discord
    • Telegram
    • Twitter
    • Medium
    • Github
    • LinkedIn
    • Instagram
    • TikTok
Powered by GitBook
On this page
  • Charged
  • Examples
  • Utilities
  • Examples
  • getStateAddress
  • getSettingsAddress
  • getManagersAddress
  • getFeesForDeposit
  • NFT
  • Examples
  • getMass
  • getCharge
  • getKinectics
  • getBonds
  • getCreatorAnnuities
  • getCreatorAnnuitiesRedirect
  • tokenURI
  • getDischargeState
  • getReleaseState
  • getBondsState
  • energize
  • discharge
  • dischargeAmount
  • dischargeForCreator
  • release
  • releaseAmount
  • bond
  • breakBond
  • releaseTimelock
  • dischargeTimelock
  • bondsTimelock
  • setCreatorAnnuities
  • setCreatorAnnuitiesRedirect

Was this helpful?

  1. SDK

API

PreviousQuick StartNextAdvanced Use

Last updated 2 years ago

Was this helpful?

Charged

Parameters

  • params ChargedConstructor Charged parameter object.

Examples

const charged = new Charged({providers: window.ethereum});
const allStateAddresses = await charged.utils.getStateAddress();

const polygonProvider = [
 { 
   network: 137, 
   service: {alchemy: process.env.ALCHEMY_POLYGON_KEY}
 }
];
const charged = new Charged({providers: polygonProvider})

ChargedConstructor

Charged class constructor object parameter.

Type:

Properties

  • signer Signer? Needed to send signed transactions to the Ethereum Network to execute state changing operations.

  • config ConfigurationParameters

Utilities

Examples

const charged = new Charged({providers: window.ethereum});
const creatorAnnuities = await charged.utils.getStateAddress();

Returns UtilsService

getStateAddress

Get the address of the chargedState contract.

getSettingsAddress

Get the address of the chargedSettings contract.

getManagersAddress

Get the address of the chargedManagers contract.

getFeesForDeposit

Get the deposit fee of the protocol.

NFT

Parameters

Examples

const charged = new Charged({providers: window.ethereum});

const nft = charged.NFT( '0xd1bce91a13089b1f3178487ab8d0d2ae191c1963', 43);

const creatorAnnuities = await nft.getCreatorAnnuities();

Returns NftService Instance of the NFT connected to the charged particle protocol

getMass

Gets the amount of asset tokens that have been deposited into the Particle.

Parameters

  • walletManagerId WalletManagerId The ID of the wallet manager to check.

Returns BigNumber The Amount of underlying assets held within the token.

getCharge

Gets the amount of interest that the particle has generated.

Parameters

  • walletManagerId WalletManagerId The ID of the Wallet Manager.

Returns BigNumber The amount of interest generated.

getKinectics

Gets the amount of LP Tokens that the Particle has generated.

Parameters

  • walletManagerId WalletManagerId The ID of the Wallet Manager.

Returns BigNumber The amount of LP tokens that have been generated.

getBonds

Gets the total amount of ERC721 tokens that the Particle holds.

Parameters

Returns BigNumber The total amount of ERC721 tokens that are held within the Particle.

getCreatorAnnuities

Gets the amount of creator annuities reserved for the creator for the specified NFT.

Returns address The address of the creator.

getCreatorAnnuitiesRedirect

Get the address that receives creator annuities for a given Particle/ Defaults to creator address if it has not been redirected.

Returns address The address of the creator.

tokenURI

Gets the tokenUri using the tokenId and contractAddress of the Particle.

getDischargeState

Gets the Discharge timelock state of the Particle.

Parameters

getReleaseState

Gets the Discharge timelock state of the Particle.

Parameters

getBondsState

Gets the Bonds Timelock state of the Particle.

Parameters

Returns BigNumber timelock

Returns BigNumber tempLockExpiry

energize

Fund particle with asset token Must be called by the account providing the asset. Account must also approve THIS contract as operator as asset.

If you are getting gas limit errors this may be because you forgot to approve the contract as operator of asset

Parameters

  • walletManagerId WalletManagerId The Asset-Pair to Energize the Token with

  • assetAmount BigNumberish The Amount of Asset Token to Energize the Token with

Examples

// Asset amount expects a big numberish type. If you do not supply a
// big number object, ethers will assume you are working in wei.
// Deposits 20 USDC tokens into our particle that will accrue interest.

const USDCoinAddress = '0xUSDC';
const result = await nft.energize(
  'aave.B',
  USDCoinAddress,
  ethers.utils.parseUnits("20", 6),
);
// Or, deposit assets that will not accrue interest
// or assets that are not supported by our yield generating protocols (e.g. aave)

// For example, we will energize our particle with 20 monkey coins
// This will not generate interest.
const monkeyCoinAddress = '0xMONKEY';
const result = await nft.energize(
  'generic.B',
  monkeyCoinAddress,
  ethers.utils.parseUnits("20")
);

discharge

Allows the owner or operator of the token to collect or transfer the interest generated from the token without removing the underlying asset that is held within the token.

Parameters

  • walletManagerId WalletManagerId The wallet manager of that assets to discharge from the token.

Examples

const myWallet = '0xWALLET';
const rocketPoolAddress = '0xRPL';
const result = await nft.discharge(
  myWallet,
  'aave.B',
  rocketPoolAddress,
);

// You can also discharge to any arbitrary wallet!
// Let's send all of our interest accrued by our DAI to Vitalik.
const vitaliksWallet = '0xCOOLGUY';
const daiAddress = '0xDAI';
const result = await nft.discharge(
  vitaliksWallet,
  'aave.B',
  daiAddress,
)

dischargeAmount

Allows the owner or operator of the Token to collect or transfer a specific amount of the interest generated from the token without removing the underlying Asset that is held within the token.

Parameters

  • walletManagerId WalletManagerId The wallet manager of the assets to discharge from the token.

  • assetAmount BigNumberish The specific amount of asset token to discharge from the particle.

dischargeForCreator

Allows the Creator of the Token to collect or transfer a their portion of the interest (if any) generated from the token without removing the underlying Asset that is held within the token.

Parameters

  • walletManagerId WalletManagerId The wallet manager of the assets to discharge from the token

  • assetAmount BigNumberish The specific amount of asset token to discharge from the particle

release

Releases the full amount of asset + interest held within the particle by LP of the assets. To release NFT assets from your particle, see break bond.

Parameters

  • walletManagerId WalletManagerId The wallet manager of the assets to release from the token.

Examples

// Release the DAI from our particle. Withdraws the interest (if any) as well!
const receiver = '0xMYWALLET';
const daiAddress = '0xDAI';
const result = nft.release(
  receiver,
  'aave.B',
  daiAddress,
);

releaseAmount

Releases a partial amount of asset + interest held within the particle by LP of the assets.

Parameters

  • walletManagerId WalletManagerId The wallet manager of the assets to release from the token

  • assetAmount BigNumberish The specific amount of asset token to release from the particle

bond

Deposit other NFT assets into the particle. Must be called by the account providing the asset. Account must approve THIS contract as operator of asset.

Parameters

Examples

const nftTokenAddress = '0xMOONBIRDS';
const tokenId = '12';
const result = await nft.bond(
  'generic.B',
  nftTokenAddress,
  tokenId,
  1,
);

// We have 12 erc-1155 nfts that we want to bond to the particle.
const nftTokenAddress = '0xCOOLGAME';
const tokenId = '78';
const result = await nft.bond(
  'generic.B',
  nftTokenAddress,
  tokenId,
  12
);

breakBond

Release NFT assets from the particle.

Parameters

Examples

// We bonded 14 erc-1155 nfts to our particle. We want to release 3.
// When working with erc-721 use 1 for nftTokenAmount.
const receiver = '0xMYWALLET';
const nftTokenAddress = '0xNFTS';
const tokenId = '35';
const result = await nft.breakBond(
  receiver,
  'generic.B',
  nftTokenAddress,
  tokenId,
  3
);

releaseTimelock

Sets a timelock on the ability to release the assets of a particle.

Parameters

dischargeTimelock

Sets a timelock on the ability to discharge the assets of a particle

Parameters

bondsTimelock

Sets a timelock on the ability to break the covalent bond of a particle

Parameters

setCreatorAnnuities

Sets the custom configuration for creators of proton-based NFTs Must be called by account that created and owns the particle

Parameters

  • annuityPercent BigNumberish The percentage of interest-annuities to reserve for the creator. In decimal this can range from 0 - 10000. 5712 would be 57.12%..

setCreatorAnnuitiesRedirect

Sets a custom receiver address for the creator annuities Must be called by account that created and owns the particle

Parameters

providers (<NetworkProvider> | providers.Provider | providers.ExternalProvider)? Provider for connection to the Ethereum network.

Returns state contract address

Returns settings contract address

Returns manager contract address

Returns protocol fee amount.

contractAddress

tokenId

assetToken The address of the asset token to check.

assetToken The address of the asset Token to check.

assetToken The Address of the Asset Token to check.

basketManagerId The ID of the BasketManager to check.

Returns The percentage amount of annuities reserved for the creator.

Returns The percentage amount of annuities reserved for the creator.

Returns Token metadata URI.

sender The address approved for Discharging assets from the Particle.

Returns [, , BigNumber, BigNumber] [allowFromAll, isApproved, timelock, empLockExpiry]

sender The address approved for Releasing assets from the Particle.

Returns [, , BigNumber, BigNumber] [allowFromAll, isApproved, timelock, empLockExpiry]

sender The address approved for removing Bond assets from the Particle.

Returns allowFromAll

Returns isApproved

assetToken The Address of the Asset Token being used

chainId ? Optional parameter that allows for the user to specify which network to write to

referrer ?

Returns <ContractTransaction> - Details from the transaction.

receiver The address to receive the discharged asset tokens.

assetToken The address of the asset token being discharged.

chainId ? Optional parameter that allows for the user to specify which network to write to.j

Returns <ContractTransaction> - Details from the transaction.

receiver The address to receive the discharged asset tokens.

assetToken The address of the asset token being discharged.

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction.

receiver The address to receive the discharged asset tokens

assetToken The address of the asset token being discharged

chainId ? Optional parameter that allows for the user to specify which network to write to

Returns <ContractTransaction> - Details from the transaction.

receiver The address to receive the released asset tokens.

assetToken The address of the asset token being released.

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction.

receiver The address to receive the released asset tokens

assetToken The address of the asset token being released

chainId ? Optional parameter that allows for the user to specify which network to write to

Returns <ContractTransaction> - Details from the transaction.

basketManagerId The basket to deposit the NFT into.

nftTokenAddress The address of the NFT token being deposited.

nftTokenId The ID of the NFT token being deposited.

nftTokenAmount The amount of tokens to deposit (ERC1155-specific).

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction.

receiver The address to receive the released asset tokens.

basketManagerId The basket to release the NFT from.

nftTokenAddress The address of the NFT token being released.

nftTokenId The ID of the NFT token being released.

nftTokenAmount The amount of tokens to deposit (ERC1155-specific).

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction

unlockBlock The Ethereum block number to timelock until (~15 seconds per block).

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction.

unlockBlock The Ethereum block number to timelock until (~15 seconds per block).

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction.

unlockBlock The Ethereum block number to timelock until (~15 seconds per block).

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction.

creator The creator's address of the proton-based NFT.

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction.

receiver The receiver of the creator interest annuities.

chainId ? Optional parameter that allows for the user to specify which network to write to.

Returns <ContractTransaction> - Details from the transaction.

Object
Array
string
string
string
string
string
number
string
string
string
string
number
number
string
string
boolean
boolean
string
boolean
boolean
string
boolean
boolean
string
number
string
Promise
Solidity Contract Method
string
string
number
Promise
Solidity Contract Method
string
string
number
Promise
Solidity Contract Method
string
string
number
Promise
Solidity Contract Method
string
string
number
Promise
Solidity Contract Method
string
string
number
Promise
Solidity Contract Method
string
string
string
number
number
Promise
Solidity Contract Method
string
string
string
string
Number
number
Promise
Solidity Contract Method
number
number
Promise
Solidity Contract Method
number
number
Promise
Solidity Contract Method
number
number
Promise
Solidity Contract Method
string
number
Promise
Solidity Contract Method
string
number
Promise
Solidity Contract Method