# Charged State Contract (V2)

## Get State Data

> Get info on time locks, approvals, and permissions.

### getDischargeTimelockExpiry

Gets unlock block for Discharge time lock.

```
function getDischargeTimelockExpiry(
  address contractAddress, 
  uint256 tokenId
) external view returns (uint256 lockExpiry);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |

| Return Value | Description                                   | Type    |
| ------------ | --------------------------------------------- | ------- |
| lockExpiry   | unlock block for Particle's Charge (interest) | uint256 |

### getReleaseTimelockExpiry

Gets unlock block for Release time lock.

```
function getReleaseTimelockExpiry(
  address contractAddress, 
  uint256 tokenId
) external view returns (uint256 lockExpiry);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |

| Return Value | Description                                             | Type    |
| ------------ | ------------------------------------------------------- | ------- |
| lockExpiry   | unlock block for Particle's Mass (principal + interest) | uint256 |

### getBreakBondTimelockExpiry

Gets unlock block for restrictions on withdrawing NFTs (Covalent Bonds) from a Particle.

```
function getBreakBondTimelockExpiry(
  address contractAddress, 
  uint256 tokenId
) external view returns (uint256 lockExpiry);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |

| Return Value | Description                                              | Type    |
| ------------ | -------------------------------------------------------- | ------- |
| lockExpiry   | unlock block for Particle's Covalent Bonds (nested NFTs) | uint256 |

### isApprovedForDischarge

Checks if an operator is allowed to Discharge a specific token (Particle).

```
function isApprovedForDischarge(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external returns (bool);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |
| operator        | address of the operator to check approval for       | address |

| Return Value | Description                                      | Type |
| ------------ | ------------------------------------------------ | ---- |
| isApproved   | true if operator approved, false if not approved | bool |

### isApprovedForRelease

Checks if an operator is allowed to Release a specific token (Particle).

```
function isApprovedForRelease(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external returns (bool);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |
| operator        | address of the operator to check approval for       | address |

| Return Value | Description                                      | Type |
| ------------ | ------------------------------------------------ | ---- |
| isApproved   | true if operator approved, false if not approved | bool |

### isApprovedForBreakBond

Checks if an operator is allowed to break Covalent Bonds on a specific token (Particle).

```
function isApprovedForBreakBond(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external returns (bool);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |
| operator        | address of the operator to check approval for       | address |

| Return Value | Description                                      | Type |
| ------------ | ------------------------------------------------ | ---- |
| isApproved   | true if operator approved, false if not approved | bool |

### isApprovedForTimelock

Checks if an operator is allowed to Timelock a specific token (Particle).

```
function isApprovedForTimelock(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external returns (bool);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |
| operator        | address of the operator to check approval for       | address |

| Return Value | Description                                      | Type |
| ------------ | ------------------------------------------------ | ---- |
| isApproved   | true if operator approved, false if not approved | bool |

### isEnergizeRestricted

Checks if energizing a specific Particle is restricted.

```
function isEnergizeRestricted(
  address contractAddress, 
  uint256 tokenId
) external view returns (bool);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |

| Return Value | Description                                      | Type |
| ------------ | ------------------------------------------------ | ---- |
| isApproved   | true if operator approved, false if not approved | bool |

### isCovalentBondRestricted

Checks if covalent bonding (depositing NFTs into a Particle) for a specific Particle is restricted.

```
function isCovalentBondRestricted(
  address contractAddress, 
  uint256 tokenId
) external view returns (bool);
```

| Parameter       | Description                                         | Type    |
| --------------- | --------------------------------------------------- | ------- |
| contractAddress | The address to the contract of the token (Particle) | address |
| tokenId         | The ID of the token (Particle)                      | uint256 |

| Return Value | Description                                      | Type |
| ------------ | ------------------------------------------------ | ---- |
| isApproved   | true if operator approved, false if not approved | bool |

### getDischargeState

Gets state of discharge settings / permissions for a Particle.

```
function getDischargeState(
  address contractAddress, 
  uint256 tokenId, 
  address sender
  ) external returns (
    bool allowFromAll, 
    bool isApproved, 
    uint256 timelock, 
    uint256 tempLockExpiry
  );
```

| Parameter                     | Description                                         | Type    |
| ----------------------------- | --------------------------------------------------- | ------- |
| contractAddress               | The address to the contract of the token (Particle) | address |
| tokenId                       | The ID of the token (Particle)                      | uint256 |
| sender                        |                                                     |         |
| address of transaction sender | address                                             |         |

| Return Value   | Description                                        | Type    |
| -------------- | -------------------------------------------------- | ------- |
| allowFromAll   | whether or not any address can release a Particle  | bool    |
| isApproved     | true if operator approved, false if not approved   | bool    |
| timelock       | unlock block for Particle's Charge (interest only) | uint256 |
| tempLockExpiry | unlock block for temporary time lock               | uint256 |

### getReleaseState

Gets state of release settings / permissions for a Particle.

```
function getReleaseState(
  address contractAddress, 
  uint256 tokenId, 
  address sender
) external returns (
  bool allowFromAll, 
  bool isApproved, 
  uint256 timelock, 
  uint256 tempLockExpiry
);
```

| Parameter                     | Description                                         | Type    |
| ----------------------------- | --------------------------------------------------- | ------- |
| contractAddress               | The address to the contract of the token (Particle) | address |
| tokenId                       | The ID of the token (Particle)                      | uint256 |
| sender                        |                                                     |         |
| address of transaction sender | address                                             |         |

| Return Value   | Description                                             | Type    |
| -------------- | ------------------------------------------------------- | ------- |
| allowFromAll   | whether or not any address can release a Particle       | bool    |
| isApproved     | true if operator approved, false if not approved        | bool    |
| timelock       | unlock block for Particle's Mass (principal + interest) | uint256 |
| tempLockExpiry | unlock block for temporary time lock                    | uint256 |

### getBreakBondState

Gets state of covalent bond breaking (releasing an NFT) settings / permissions for a Particle.

```
function getBreakBondState(
  address contractAddress, 
  uint256 tokenId, 
  address sender
) external returns (
  bool allowFromAll,
  bool isApproved,
  uint256 timelock,
  uint256 tempLockExpiry
);
```

| Parameter                     | Description                                         | Type    |
| ----------------------------- | --------------------------------------------------- | ------- |
| contractAddress               | The address to the contract of the token (Particle) | address |
| tokenId                       | The ID of the token (Particle)                      | uint256 |
| sender                        |                                                     |         |
| address of transaction sender | address                                             |         |

| Return Value   | Description                                              | Type    |
| -------------- | -------------------------------------------------------- | ------- |
| allowFromAll   | whether or not any address can release a Particle        | bool    |
| isApproved     | true if operator approved, false if not approved         | bool    |
| timelock       | unlock block for Particle's Covalent Bonds (nested NFTs) | uint256 |
| tempLockExpiry | unlock block for temporary time lock                     | uint256 |

## Set Permissions + Approvals

> Update a Particle's permissions and approvals. Only the owner or operator of an NFT can call these functions.

### setDischargeApproval

Sets an operator as approved to Discharge a specific token (Particle); This allows an operator to withdraw the interest-portion only.

```
function setDischargeApproval(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external;
```

| Parameter           | Description                                         | Type    |
| ------------------- | --------------------------------------------------- | ------- |
| contractAddress     | The address to the contract of the token (Particle) | address |
| tokenId             | The ID of the token (Particle)                      | uint256 |
| operator            |                                                     |         |
| Particle's operator | address                                             |         |

### setReleaseApproval

Sets an operator as approved to Release a specific token (Particle); This allows an operator to withdraw the principal + interest.

```
function setReleaseApproval(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external;
```

| Parameter           | Description                                         | Type    |
| ------------------- | --------------------------------------------------- | ------- |
| contractAddress     | The address to the contract of the token (Particle) | address |
| tokenId             | The ID of the token (Particle)                      | uint256 |
| operator            |                                                     |         |
| Particle's operator | address                                             |         |

### setBreakBondApproval

Sets an operator as approved to break Covalent Bonds on a specific token (Particle); This allows an operator to withdraw NFTs.

```
function setBreakBondApproval(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external;
```

| Parameter           | Description                                         | Type    |
| ------------------- | --------------------------------------------------- | ------- |
| contractAddress     | The address to the contract of the token (Particle) | address |
| tokenId             | The ID of the token (Particle)                      | uint256 |
| operator            |                                                     |         |
| Particle's operator | address                                             |         |

### setTimelockApproval

Sets an operator as approved to Timelock a specific token (Particle); This allows an operator to timelock the principal or interest.

```
function setTimelockApproval(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external;
```

| Parameter            | Description                                         | Type    |
| -------------------- | --------------------------------------------------- | ------- |
| contractAddress      | The address to the contract of the token (Particle) | address |
| tokenId              | The ID of the token (Particle)                      | uint256 |
| operator             |                                                     |         |
| Particle's operator  | address                                             |         |
| ## setApprovalForAll |                                                     |         |

Sets an operator as approved to Discharge/Release/Timelock a specific token (Particle).

```
function setApprovalForAll(
  address contractAddress, 
  uint256 tokenId, 
  address operator
) external;
```

| Parameter           | Description                                         | Type    |
| ------------------- | --------------------------------------------------- | ------- |
| contractAddress     | The address to the contract of the token (Particle) | address |
| tokenId             | The ID of the token (Particle)                      | uint256 |
| operator            |                                                     |         |
| Particle's operator | address                                             |         |

### setPermsForRestrictCharge

Updates restrictions on Energizing an NFT.

```
function setPermsForRestrictCharge(
  address contractAddress, 
  uint256 tokenId, 
  bool state
) external;
```

| Parameter                       | Description                                         | Type    |
| ------------------------------- | --------------------------------------------------- | ------- |
| contractAddress                 | The address to the contract of the token (Particle) | address |
| tokenId                         | The ID of the token (Particle)                      | uint256 |
| state                           |                                                     |         |
| state of permissions for action | bool                                                |         |

### setPermsForAllowDischarge

Updates allowance on Discharging an NFT by anyone.

```
function setPermsForAllowDischarge(
  address contractAddress, 
  uint256 tokenId, 
  bool state
) external;
```

| Parameter                       | Description                                         | Type    |
| ------------------------------- | --------------------------------------------------- | ------- |
| contractAddress                 | The address to the contract of the token (Particle) | address |
| tokenId                         | The ID of the token (Particle)                      | uint256 |
| state                           |                                                     |         |
| state of permissions for action | bool                                                |         |

### setPermsForAllowRelease

Updates allowance on Discharging an NFT by anyone.

```
function setPermsForAllowRelease(
  address contractAddress, 
  uint256 tokenId, 
  bool state
) external;
```

| Parameter                       | Description                                         | Type    |
| ------------------------------- | --------------------------------------------------- | ------- |
| contractAddress                 | The address to the contract of the token (Particle) | address |
| tokenId                         | The ID of the token (Particle)                      | uint256 |
| state                           |                                                     |         |
| state of permissions for action | bool                                                |         |

### setPermsForRestrictBond

Updates restrictions on Covalent Bonds on an NFT.

```
function setPermsForRestrictBond(
  address contractAddress, 
  uint256 tokenId, 
  bool state
) external;
```

| Parameter                       | Description                                         | Type    |
| ------------------------------- | --------------------------------------------------- | ------- |
| contractAddress                 | The address to the contract of the token (Particle) | address |
| tokenId                         | The ID of the token (Particle)                      | uint256 |
| state                           |                                                     |         |
| state of permissions for action | bool                                                |         |

### setPermsForAllowBreakBond

Updates allowance on Breaking Covalent Bonds on an NFT by anyone.

```
function setPermsForAllowBreakBond(
  address contractAddress, 
  uint256 tokenId, 
  bool state
) external;
```

| Parameter                       | Description                                         | Type    |
| ------------------------------- | --------------------------------------------------- | ------- |
| contractAddress                 | The address to the contract of the token (Particle) | address |
| tokenId                         | The ID of the token (Particle)                      | uint256 |
| state                           |                                                     |         |
| state of permissions for action | bool                                                |         |

### setDischargeTimelock

Sets a Timelock on the ability to Discharge the interest of a Particle.

```
function setDischargeTimelock(
  address contractAddress,
  uint256 tokenId,
  uint256 unlockBlock
) external;
```

| Parameter                                            | Description                                         | Type    |
| ---------------------------------------------------- | --------------------------------------------------- | ------- |
| contractAddress                                      | The address to the contract of the token (Particle) | address |
| tokenId                                              | The ID of the token (Particle)                      | uint256 |
| unlockBlock                                          |                                                     |         |
| unlock block for Discharge time lock (interest only) | uint256                                             |         |

### setReleaseTimelock

Sets a Timelock on the ability to Release the assets of a Particle.

```
function setReleaseTimelock(
  address contractAddress,
  uint256 tokenId,
  uint256 unlockBlock
) external;
```

| Parameter                                                 | Description                                         | Type    |
| --------------------------------------------------------- | --------------------------------------------------- | ------- |
| contractAddress                                           | The address to the contract of the token (Particle) | address |
| tokenId                                                   | The ID of the token (Particle)                      | uint256 |
| unlockBlock                                               |                                                     |         |
| unlock block for Release time lock (principal + interest) | uint256                                             |         |

### setBreakBondTimelock

Sets a Timelock on the ability to break the Covalent Bond of a Particle.

```
function setBreakBondTimelock(
  address contractAddress,
  uint256 tokenId,
  uint256 unlockBlock
) external;
```

| Parameter                                               | Description                                         | Type    |
| ------------------------------------------------------- | --------------------------------------------------- | ------- |
| contractAddress                                         | The address to the contract of the token (Particle) | address |
| tokenId                                                 | The ID of the token (Particle)                      | uint256 |
| unlockBlock                                             |                                                     |         |
| unlock block for Covalent Bonds (nested NFTs) time lock | uint256                                             |         |

### setTemporaryLock

Sets a temporary Timelock on the ability to Release/Discharge the assets of a Particle.

```
function setTemporaryLock(
  address contractAddress,
  uint256 tokenId,
  bool isLocked
) external;
```

| Parameter          | Description                                         | Type    |
| ------------------ | --------------------------------------------------- | ------- |
| contractAddress    | The address to the contract of the token (Particle) | address |
| tokenId            | The ID of the token (Particle)                      | uint256 |
| isLocked           |                                                     |         |
| state of time lock | bool                                                |         |

## Other

### Events

```
event Initialized(address indexed initiator);
```

```
  event ControllerSet(address indexed controllerAddress, string controllerId);
```

```
  event DischargeApproval(address indexed contractAddress, uint256 indexed tokenId, address indexed owner, address operator);
```

```
  event ReleaseApproval(address indexed contractAddress, uint256 indexed tokenId, address indexed owner, address operator);
```

```
  event BreakBondApproval(address indexed contractAddress, uint256 indexed tokenId, address indexed owner, address operator);
```

```
  event TimelockApproval(address indexed contractAddress, uint256 indexed tokenId, address indexed owner, address operator);
```

```
  event TokenDischargeTimelock(address indexed contractAddress, uint256 indexed tokenId, address indexed operator, uint256 unlockBlock);
```

```
  event TokenReleaseTimelock(address indexed contractAddress, uint256 indexed tokenId, address indexed operator, uint256 unlockBlock);
```

```
  event TokenBreakBondTimelock(address indexed contractAddress, uint256 indexed tokenId, address indexed operator, uint256 unlockBlock);
```

```
  event TokenTempLock(address indexed contractAddress, uint256 indexed tokenId, uint256 unlockBlock);
```

```
  event PermsSetForRestrictCharge(address indexed contractAddress, uint256 indexed tokenId, bool state);
```

```
  event PermsSetForAllowDischarge(address indexed contractAddress, uint256 indexed tokenId, bool state);
```

```
  event PermsSetForAllowRelease(address indexed contractAddress, uint256 indexed tokenId, bool state);
```

```
  event PermsSetForRestrictBond(address indexed contractAddress, uint256 indexed tokenId, bool state);
```

```
  event PermsSetForAllowBreakBond(address indexed contractAddress, uint256 indexed tokenId, bool state);
```


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.charged.fi/charged-particles-protocol/developing-on-the-protocol/smart-contracts/v2/charged-state-contract-v2.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
