<!--
order: 2
-->

# State

For detail on the state tracked by the cdp module see the types package. In particular [keys.go](../types/keys.go) describes how state is stored in the key-value store.

## Module Accounts

The cdp module account controls two module accounts:

**CDP Account:** Stores the deposited cdp collateral, and the debt coins for the debt in all the cdps.

**Liquidator Account:** Stores debt coins that have been seized by the system, and any stable asset that has been raised through auctions.

## CDP

A CDP is a struct representing a debt position owned by one address. It has one collateral type and records the debt that has been drawn and how much fees should be repaid.

Only an owner is authorized to draw or repay debt, but anyone can deposit collateral to a CDP. Deposits are scoped per address and are recorded separately in `Deposit` types. Depositors are free to withdraw their collateral provided it does not put the CDP below the liquidation ratio.

The CDP's collateral always equal to the total of the deposits.

```go
type CDP struct {
    ID              uint64
    Owner           sdk.AccAddress
    Type            string
    Collateral      sdk.Coin
    Principal       sdk.Coin
    AccumulatedFees sdk.Coin
    FeesUpdated     time.Time
    InterestFactor  sdk.Dec
}
```

CDPs are stored with three database indexes for faster lookup:

- by collateral ratio - to look up cdps that are close to the liquidation ratio
- by collateral denom - to look up cdps with a particular collateral asset
- by owner index - to look up cdps that an address is the owner of

## Deposit

A Deposit is a struct recording collateral added to a CDP by one address. The address only has authorization to change their deposited amount (provided it does not put the CDP below the liquidation ratio).

```go
type Deposit struct {
    CdpID         uint64
    Depositor     sdk.AccAddress
    Amount        sdk.Coin
}
```

## Params

Module parameters controlled by governance. See [Parameters](04_params.md) for details.

## NextCDPID

A global counter used to create unique CDP ids.

## DebtDenom

The name of the internal debt coin. Its value can be configured at genesis.

## GovDenom

The name of the internal governance coin. Its value can be configured at genesis.

## Total Principle

Sum of all non seized debt plus accumulated fees.

## Previous Savings Distribution Time

A record of the last block time when the savings rate was distributed