<!-- order: 3 --> # Messages The issuer can issue new tokens using a `MsgIssueTokens` ```go // MsgIssueTokens message type used to issue tokens type MsgIssueTokens struct { Sender sdk.AccAddress `json:"sender" yaml:"sender"` Tokens sdk.Coin `json:"tokens" yaml:"tokens"` Receiver sdk.AccAddress `json:"receiver" yaml:"receiver"` } ``` ## State Modifications * New tokens are minted from the issuance module account * New tokens are transferred from the module account to the receiver The issuer can redeem (burn) tokens using `MsgRedeemTokens`. ```go // MsgRedeemTokens message type used to redeem (burn) tokens type MsgRedeemTokens struct { Sender sdk.AccAddress `json:"sender" yaml:"sender"` Tokens sdk.Coin `json:"tokens" yaml:"tokens"` } ``` ## State Modifications * Tokens are transferred from the owner address to the issuer module account * Tokens are burned Addresses can be added to the blocked list using `MsgBlockAddress` ```go // MsgBlockAddress message type used by the issuer to block an address from holding or transferring tokens type MsgBlockAddress struct { Sender sdk.AccAddress `json:"sender" yaml:"sender"` Denom string `json:"denom" yaml:"denom"` BlockedAddress sdk.AccAddress `json:"blocked_address" yaml:"blocked_address"` } ``` ## State Modifications * The address is added to the block list, which prevents the account from holding coins of that denom * Tokens are sent back to the issuer The issuer can pause or un-pause the contract using `MsgChangePauseStatus` ```go // MsgChangePauseStatus message type used by the issuer to issue new tokens type MsgChangePauseStatus struct { Sender sdk.AccAddress `json:"sender" yaml:"sender"` Denom string `json:"denom" yaml:"denom"` Status bool `json:"status" yaml:"status"` } ``` ## State Modifications * The `Paused` value of the correspond asset is updated to `Status`. * Issuance and redemption are paused if `Paused` is false