cooldown
CoolDown
🔗
Bases: BaseDispatcher
, Generic[T_SourceKey]
指示需要冷却时间才能执行操作
Source code in src/graia/ariadne/util/cooldown.py
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 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 |
|
__init__(interval, source=None, override_condition=lambda: False, stop_on_cooldown=True)
🔗
初始化一个冷却时间
Parameters:
Name | Type | Description | Default |
---|---|---|---|
interval
|
Union[int, float, timedelta]
|
冷却时间, 单位为秒 |
required |
source
|
Union[MutableMapping[int, datetime], str, None]
|
冷却映射来源, 为字符串时从 ClassVar 查找. |
None
|
override_condition
|
...) -> Union[bool, Awaitable[bool]]
|
超越冷却限制的条件. |
lambda: False
|
stop_on_cooldown
|
bool
|
是否在未到冷却时间时直接停止执行. Defaults to True. |
True
|
Source code in src/graia/ariadne/util/cooldown.py
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 |
|
fetch_target_key(event)
async
🔗
获取目标的键,以在 source 中获取对应的冷却信息
Parameters:
Name | Type | Description | Default |
---|---|---|---|
event
|
Dispatchable
|
当前事件 |
required |
Returns:
Name | Type | Description |
---|---|---|
T_SourceKey |
T_SourceKey
|
目标的 “冷却哈希” |
Source code in src/graia/ariadne/util/cooldown.py
74 75 76 77 78 79 80 81 82 83 84 85 |
|
get(target, type)
async
🔗
获取目标的冷却信息
Parameters:
Name | Type | Description | Default |
---|---|---|---|
target
|
T_SourceKey
|
目标的 “冷却哈希” |
required |
type
|
Type[T_Time]
|
需要返回的类型 |
required |
Returns:
Type | Description |
---|---|
Tuple[T_Time, bool]
|
Tuple[T_Time, bool]: 第一个值是剩余的冷却时间 (或下一次可执行时间), 第二个值是冷却是否完成 如果 type 传入的是 Optional[XXX] 则第一个值可以是 None |
Source code in src/graia/ariadne/util/cooldown.py
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 |
|
set(target)
async
🔗
更新目标的冷却信息
Parameters:
Name | Type | Description | Default |
---|---|---|---|
target
|
T_SourceKey
|
目标的 “冷却哈希” |
required |
Source code in src/graia/ariadne/util/cooldown.py
117 118 119 120 121 122 123 |
|
trigger(target, type)
async
🔗
trigger(
target: int,
) -> AsyncGenerator[Tuple[Optional[datetime], bool], None]
trigger(
target: int, type: Type[T_Time]
) -> AsyncGenerator[Tuple[T_Time, bool], None]
触发冷却。
Parameters:
Name | Type | Description | Default |
---|---|---|---|
target
|
T_SourceKey
|
目标的 “冷却哈希” |
required |
type
|
Type[T_Time]
|
需要返回的类型 |
required |
Source code in src/graia/ariadne/util/cooldown.py
179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 |
|