Charged Particles Javascript SDK v0.1.8 (beta)
- Charged
- NFT
- Parameters
- Examples
- getMass
- getCharge
- getKinectics
- getBonds
- getCreatorAnnuities
- getCreatorAnnuitiesRedirect
- tokenURI
- getDischargeState
- getReleaseState
- getBondsState
- energize
- discharge
- dischargeAmount
- dischargeForCreator
- release
- releaseAmount
- bond
- breakBond
- releaseTimelock
- dischargeTimelock
- bondsTimelock
- setCreatorAnnuities
- setCreatorAnnuitiesRedirect
- Types
- Utilities
paramsChargedConstructor Charged parameter object.
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})Charged class constructor object parameter.
Type: Object
providers(Array<NetworkProvider> | providers.Provider | providers.ExternalProvider)? Provider for connection to the Ethereum network.signerSigner? Needed to send signed transactions to the Ethereum Network to execute state changing operations.configConfigurationParameters
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
Gets the amount of asset tokens that have been deposited into the Particle.
walletManagerIdManagerId The ID of the wallet manager to check.assetTokenstring The address of the asset token to check.
Returns BigNumber The Amount of underlying assets held within the token.
Gets the amount of interest that the particle has generated.
walletManagerIdManagerId The ID of the Wallet Manager.assetTokenstring The address of the asset Token to check.
Returns BigNumber The amount of interest generated.
Gets the amount of LP Tokens that the Particle has generated.
walletManagerIdManagerId The ID of the Wallet Manager.assetTokenstring The Address of the Asset Token to check.
Returns BigNumber The amount of LP tokens that have been generated.
Gets the total amount of ERC721 tokens that the Particle holds.
basketManagerIdstring The ID of the BasketManager to check.
Returns BigNumber The total amount of ERC721 tokens that are held within the Particle.
Gets the amount of creator annuities reserved for the creator for the specified NFT.
Returns address The address of the creator.
Returns number The percentage amount of annuities reserved for the creator.
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.
Returns number The percentage amount of annuities reserved for the creator.
Gets the tokenUri using the tokenId and contractAddress of the Particle.
Returns string Token metadata URI.
Gets the Discharge timelock state of the Particle.
senderstring The address approved for Discharging assets from the Particle.
Returns [boolean, boolean, BigNumber, BigNumber] [allowFromAll, isApproved, timelock, empLockExpiry]
Gets the Discharge timelock state of the Particle.
senderstring The address approved for Releasing assets from the Particle.
Returns [boolean, boolean, BigNumber, BigNumber] [allowFromAll, isApproved, timelock, empLockExpiry]
Gets the Bonds Timelock state of the Particle.
senderstring The address approved for removing Bond assets from the Particle.
Returns boolean allowFromAll
Returns boolean isApproved
Returns BigNumber timelock
Returns BigNumber empLockExpiry
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
walletManagerIdManagerId The Asset-Pair to Energize the Token withassetTokenstring The Address of the Asset Token being usedassetAmountBigNumberish The Amount of Asset Token to Energize the Token withchainIdnumber? Optional parameter that allows for the user to specify which network to write toreferrerstring?
// 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")
);Returns Promise<ContractTransaction> A contract receipt from the transaction.Solidity Contract Method
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.
receiverstring The address to receive the discharged asset tokens.walletManagerIdManagerId The wallet manager of that assets to discharge from the token.assetTokenstring The address of the asset token being discharged.chainIdnumber? Optional parameter that allows for the user to specify which network to write to.j
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,
)Returns Promise<ContractTransaction> A receipt from the contract transaction.Solidity Contract Method
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.
receiverstring The address to receive the discharged asset tokens.walletManagerIdManagerId The wallet manager of the assets to discharge from the token.assetTokenstring The address of the asset token being discharged.assetAmountBigNumberish The specific amount of asset token to discharge from the particle.chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
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.
receiverstring The address to receive the discharged asset tokenswalletManagerIdManagerId The wallet manager of the assets to discharge from the tokenassetTokenstring The address of the asset token being dischargedassetAmountBigNumberish The specific amount of asset token to discharge from the particlechainIdnumber? Optional parameter that allows for the user to specify which network to write to
Returns Promise<ContractTransaction> A receipt from the transactionSolidity Contract Method
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.
receiverstring The address to receive the released asset tokens.walletManagerIdManagerId The wallet manager of the assets to release from the token.assetTokenstring The address of the asset token being released.chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
// 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,
);Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
Releases a partial amount of asset + interest held within the particle by LP of the assets.
receiverstring The address to receive the released asset tokenswalletManagerIdManagerId The wallet manager of the assets to release from the tokenassetTokenstring The address of the asset token being releasedassetAmountBigNumberish The specific amount of asset token to release from the particlechainIdnumber? Optional parameter that allows for the user to specify which network to write to
Returns Promise<ContractTransaction> A receipt from the transactionSolidity Contract Method
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.
basketManagerIdstring The basket to deposit the NFT into.nftTokenAddressstring The address of the NFT token being deposited.nftTokenIdstring The ID of the NFT token being deposited.nftTokenAmountnumber The amount of tokens to deposit (ERC1155-specific).chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
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
);Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
Release NFT assets from the particle.
receiverstring The address to receive the released asset tokens.basketManagerIdstring The basket to release the NFT from.nftTokenAddressstring The address of the NFT token being released.nftTokenIdstring The ID of the NFT token being released.nftTokenAmountNumber The amount of tokens to deposit (ERC1155-specific).chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
// 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
);Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
Sets a timelock on the ability to release the assets of a particle.
unlockBlocknumber The Ethereum block number to timelock until (~15 seconds per block).chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
Sets a timelock on the ability to discharge the assets of a particle
unlockBlocknumber The Ethereum block number to timelock until (~15 seconds per block).chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
Sets a timelock on the ability to break the covalent bond of a particle
unlockBlocknumber The Ethereum block number to timelock until (~15 seconds per block).chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
Sets the custom configuration for creators of proton-based NFTs Must be called by account that created and owns the particle
creatorstring The creator's address of the proton-based NFT.annuityPercentBigNumberish The percentage of interest-annuities to reserve for the creator. In decimal this can range from 0 - 10000. 5712 would be 57.12%..chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
Sets a custom receiver address for the creator annuities Must be called by account that created and owns the particle
receiverstring The receiver of the creator interest annuities.chainIdnumber? Optional parameter that allows for the user to specify which network to write to.
Returns Promise<ContractTransaction> Details from the transaction.Solidity Contract Method
const charged = new Charged({providers: window.ethereum});
const creatorAnnuities = await charged.utils.getStateAddress();Returns UtilsService
Get the address of the chargedState contract.
Returns string state contract address
Get the address of the chargedSettings contract.
Returns string settings contract address
Get the address of the chargedManagers contract.
Returns string manager contract address
User specified custom network provider.
Type: Object
networknumber? Configure the SDK.
const providers = [
{
network: 1,
service: { 'alchemy': process.env.ALCHEMY_MAINNET_KEY }
},
{
network: 42,
service: { 'infura': process.env.INFURA_KOVAN_KEY }
}
];
const rpcUrlProvider = [
{
network: 42,
service: { 'rpc': `https://kovan.infura.io/v3/${process.env.INFURA_PROJECT_SECRET}`}
}
];A string enum that identifies which wallet manager to use. Used in functions like release and discharge
Type: ManagerId
ManagerIdstring possible values:aave,aave.B,generic,generic.B
Charged class constructor object parameter.
Type: Object
sdkSdkConfiguration? Configure the SDK.transactionOverrideTransactionOverride? Override transaction default values.
SDK configuration.
Type: Object
NftBridgeCheckboolean? Verifies that the signer network matches the chainId of the contract interaction.
Overrides ethers transaction default parameters.
Type: Object
Get the deposit fee of the protocol.
Returns string protocol fee amount.