1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158
// @generated
/// BasicAllowance implements Allowance with a one-time grant of coins
/// that optionally expires. The grantee can use up to SpendLimit to cover fees.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct BasicAllowance {
/// spend_limit specifies the maximum amount of coins that can be spent
/// by this allowance and will be updated as coins are spent. If it is
/// empty, there is no spend limit and any amount of coins can be spent.
#[prost(message, repeated, tag = "1")]
pub spend_limit: ::prost::alloc::vec::Vec<super::super::base::v1beta1::Coin>,
/// expiration specifies an optional time when this allowance expires
#[prost(message, optional, tag = "2")]
pub expiration: ::core::option::Option<::prost_types::Timestamp>,
}
/// PeriodicAllowance extends Allowance to allow for both a maximum cap,
/// as well as a limit per time period.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct PeriodicAllowance {
/// basic specifies a struct of `BasicAllowance`
#[prost(message, optional, tag = "1")]
pub basic: ::core::option::Option<BasicAllowance>,
/// period specifies the time duration in which period_spend_limit coins can
/// be spent before that allowance is reset
#[prost(message, optional, tag = "2")]
pub period: ::core::option::Option<::prost_types::Duration>,
/// period_spend_limit specifies the maximum number of coins that can be spent
/// in the period
#[prost(message, repeated, tag = "3")]
pub period_spend_limit: ::prost::alloc::vec::Vec<super::super::base::v1beta1::Coin>,
/// period_can_spend is the number of coins left to be spent before the period_reset time
#[prost(message, repeated, tag = "4")]
pub period_can_spend: ::prost::alloc::vec::Vec<super::super::base::v1beta1::Coin>,
/// period_reset is the time at which this period resets and a new one begins,
/// it is calculated from the start time of the first transaction after the
/// last period ended
#[prost(message, optional, tag = "5")]
pub period_reset: ::core::option::Option<::prost_types::Timestamp>,
}
/// AllowedMsgAllowance creates allowance only for specified message types.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct AllowedMsgAllowance {
/// allowance can be any of basic and periodic fee allowance.
#[prost(message, optional, tag = "1")]
pub allowance: ::core::option::Option<::prost_types::Any>,
/// allowed_messages are the messages for which the grantee has the access.
#[prost(string, repeated, tag = "2")]
pub allowed_messages: ::prost::alloc::vec::Vec<::prost::alloc::string::String>,
}
/// Grant is stored in the KVStore to record a grant with full context
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct Grant {
/// granter is the address of the user granting an allowance of their funds.
#[prost(string, tag = "1")]
pub granter: ::prost::alloc::string::String,
/// grantee is the address of the user being granted an allowance of another user's funds.
#[prost(string, tag = "2")]
pub grantee: ::prost::alloc::string::String,
/// allowance can be any of basic, periodic, allowed fee allowance.
#[prost(message, optional, tag = "3")]
pub allowance: ::core::option::Option<::prost_types::Any>,
}
/// GenesisState contains a set of fee allowances, persisted from the store
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct GenesisState {
#[prost(message, repeated, tag = "1")]
pub allowances: ::prost::alloc::vec::Vec<Grant>,
}
/// QueryAllowanceRequest is the request type for the Query/Allowance RPC method.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct QueryAllowanceRequest {
/// granter is the address of the user granting an allowance of their funds.
#[prost(string, tag = "1")]
pub granter: ::prost::alloc::string::String,
/// grantee is the address of the user being granted an allowance of another user's funds.
#[prost(string, tag = "2")]
pub grantee: ::prost::alloc::string::String,
}
/// QueryAllowanceResponse is the response type for the Query/Allowance RPC method.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct QueryAllowanceResponse {
/// allowance is a allowance granted for grantee by granter.
#[prost(message, optional, tag = "1")]
pub allowance: ::core::option::Option<Grant>,
}
/// QueryAllowancesRequest is the request type for the Query/Allowances RPC method.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct QueryAllowancesRequest {
#[prost(string, tag = "1")]
pub grantee: ::prost::alloc::string::String,
/// pagination defines an pagination for the request.
#[prost(message, optional, tag = "2")]
pub pagination: ::core::option::Option<super::super::base::query::v1beta1::PageRequest>,
}
/// QueryAllowancesResponse is the response type for the Query/Allowances RPC method.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct QueryAllowancesResponse {
/// allowances are allowance's granted for grantee by granter.
#[prost(message, repeated, tag = "1")]
pub allowances: ::prost::alloc::vec::Vec<Grant>,
/// pagination defines an pagination for the response.
#[prost(message, optional, tag = "2")]
pub pagination: ::core::option::Option<super::super::base::query::v1beta1::PageResponse>,
}
/// QueryAllowancesByGranterRequest is the request type for the Query/AllowancesByGranter RPC method.
///
/// Since: cosmos-sdk 0.46
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct QueryAllowancesByGranterRequest {
#[prost(string, tag = "1")]
pub granter: ::prost::alloc::string::String,
/// pagination defines an pagination for the request.
#[prost(message, optional, tag = "2")]
pub pagination: ::core::option::Option<super::super::base::query::v1beta1::PageRequest>,
}
/// QueryAllowancesByGranterResponse is the response type for the Query/AllowancesByGranter RPC method.
///
/// Since: cosmos-sdk 0.46
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct QueryAllowancesByGranterResponse {
/// allowances that have been issued by the granter.
#[prost(message, repeated, tag = "1")]
pub allowances: ::prost::alloc::vec::Vec<Grant>,
/// pagination defines an pagination for the response.
#[prost(message, optional, tag = "2")]
pub pagination: ::core::option::Option<super::super::base::query::v1beta1::PageResponse>,
}
/// MsgGrantAllowance adds permission for Grantee to spend up to Allowance
/// of fees from the account of Granter.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct MsgGrantAllowance {
/// granter is the address of the user granting an allowance of their funds.
#[prost(string, tag = "1")]
pub granter: ::prost::alloc::string::String,
/// grantee is the address of the user being granted an allowance of another user's funds.
#[prost(string, tag = "2")]
pub grantee: ::prost::alloc::string::String,
/// allowance can be any of basic, periodic, allowed fee allowance.
#[prost(message, optional, tag = "3")]
pub allowance: ::core::option::Option<::prost_types::Any>,
}
/// MsgGrantAllowanceResponse defines the Msg/GrantAllowanceResponse response type.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct MsgGrantAllowanceResponse {}
/// MsgRevokeAllowance removes any existing Allowance from Granter to Grantee.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct MsgRevokeAllowance {
/// granter is the address of the user granting an allowance of their funds.
#[prost(string, tag = "1")]
pub granter: ::prost::alloc::string::String,
/// grantee is the address of the user being granted an allowance of another user's funds.
#[prost(string, tag = "2")]
pub grantee: ::prost::alloc::string::String,
}
/// MsgRevokeAllowanceResponse defines the Msg/RevokeAllowanceResponse response type.
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct MsgRevokeAllowanceResponse {}
include!("cosmos.feegrant.v1beta1.tonic.rs");
// @@protoc_insertion_point(module)