pub struct Addr(/* private fields */);Expand description
A human readable address.
In Cosmos, this is typically bech32 encoded. But for multi-chain smart contracts no assumptions should be made other than being UTF-8 encoded and of reasonable length.
This type represents a validated address. It can be created in the following ways
- Use Addr::unchecked(input)
- Use let checked: Addr = deps.api.addr_validate(input)?
- Use let checked: Addr = deps.api.addr_humanize(canonical_addr)?
- Deserialize from JSON. This must only be done from JSON that was validated before
such as a contract’s state. Addrmust not be used in messages sent by the user because this would result in unvalidated instances.
This type is immutable. If you really need to mutate it (Really? Are you sure?), create
a mutable copy using let mut mutable = Addr::to_string() and operate on that String
instance.
Implementations§
Source§impl Addr
 
impl Addr
Sourcepub fn unchecked(input: impl Into<String>) -> Addr
 
pub fn unchecked(input: impl Into<String>) -> Addr
Creates a new Addr instance from the given input without checking the validity
of the input. Since Addr must always contain valid addresses, the caller is
responsible for ensuring the input is valid.
Use this in cases where the address was validated before or in test code.
If you see this in contract code, it should most likely be replaced with
let checked: Addr = deps.api.addr_humanize(canonical_addr)?.
§Examples
let address = Addr::unchecked("foobar");
assert_eq!(address, "foobar");pub fn as_str(&self) -> &str
Sourcepub fn as_bytes(&self) -> &[u8] ⓘ
 
pub fn as_bytes(&self) -> &[u8] ⓘ
Returns the UTF-8 encoded address string as a byte array.
This is equivalent to address.as_str().as_bytes().
Sourcepub fn into_string(self) -> String
 
pub fn into_string(self) -> String
Utility for explicit conversion to String.
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Addr
 
impl<'de> Deserialize<'de> for Addr
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
    __D: Deserializer<'de>,
 
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
    __D: Deserializer<'de>,
Source§impl JsonSchema for Addr
 
impl JsonSchema for Addr
Source§fn schema_name() -> String
 
fn schema_name() -> String
Source§fn schema_id() -> Cow<'static, str>
 
fn schema_id() -> Cow<'static, str>
Source§fn json_schema(gen: &mut SchemaGenerator) -> Schema
 
fn json_schema(gen: &mut SchemaGenerator) -> Schema
Source§fn is_referenceable() -> bool
 
fn is_referenceable() -> bool
$ref keyword. Read moreSource§impl Ord for Addr
 
impl Ord for Addr
Source§impl PartialEq<&str> for Addr
Implement Addr == &str
 
impl PartialEq<&str> for Addr
Implement Addr == &str
Deprecated. This comparison unsafe. Convert both sides to Addr first. Will be removed soon: https://github.com/CosmWasm/cosmwasm/issues/1669
Source§impl PartialEq<Addr> for &str
Implement &str == Addr
 
impl PartialEq<Addr> for &str
Implement &str == Addr
Deprecated. This comparison unsafe. Convert both sides to Addr first. Will be removed soon: https://github.com/CosmWasm/cosmwasm/issues/1669
Source§impl PartialEq<Addr> for String
Implement String == Addr
 
impl PartialEq<Addr> for String
Implement String == Addr
Deprecated. This comparison unsafe. Convert both sides to Addr first. Will be removed soon: https://github.com/CosmWasm/cosmwasm/issues/1669
Source§impl PartialEq<String> for Addr
Implement Addr == String
 
impl PartialEq<String> for Addr
Implement Addr == String
Deprecated. This comparison unsafe. Convert both sides to Addr first. Will be removed soon: https://github.com/CosmWasm/cosmwasm/issues/1669