Commit 722e959
Handle Retry-After header on 429/503 responses
Relevant standards: RFC 6585 / RFC 9110
Merges and fixes https://github.com/python-tcaldav/caldav/pull/628 by temsocial
New `DAVClient` parameters:
- `rate_limit_handle` (bool, default False): when True, automatically sleep
and retry on rate-limited responses; when False raise `RateLimitError`
immediately so callers can implement their own strategy.
- `rate_limit_default_sleep` (Optional[int], default None): fallback sleep
in seconds when the server's 429 omits a Retry-After header. None means
raise rather than guess a sleep duration.
- `rate_limit_max_sleep` (Optional[int], default None): cap on the sleep
duration; None means respect the server's value without limit.
New `error.RateLimitError(DAVError)` with `retry_after` (raw header string)
and `retry_after_seconds` (parsed float) attributes.
11 unit tests added to `TestRateLimiting` in `tests/test_caldav_unit.py`.
Co-authored-by: temsocial <temsocial@users.noreply.github.com>
Assisted-by: Claude Sonnet 4.6 <noreply@anthropic.com>1 parent 32620d6 commit 722e959
4 files changed
Lines changed: 343 additions & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
98 | 98 | | |
99 | 99 | | |
100 | 100 | | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
101 | 119 | | |
102 | 120 | | |
103 | 121 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| 13 | + | |
13 | 14 | | |
| 15 | + | |
| 16 | + | |
14 | 17 | | |
15 | 18 | | |
16 | 19 | | |
| |||
206 | 209 | | |
207 | 210 | | |
208 | 211 | | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
209 | 215 | | |
210 | 216 | | |
211 | 217 | | |
| |||
243 | 249 | | |
244 | 250 | | |
245 | 251 | | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
246 | 262 | | |
247 | 263 | | |
248 | 264 | | |
| |||
341 | 357 | | |
342 | 358 | | |
343 | 359 | | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
344 | 364 | | |
345 | 365 | | |
346 | 366 | | |
| |||
931 | 951 | | |
932 | 952 | | |
933 | 953 | | |
934 | | - | |
| 954 | + | |
| 955 | + | |
| 956 | + | |
| 957 | + | |
| 958 | + | |
| 959 | + | |
| 960 | + | |
| 961 | + | |
| 962 | + | |
| 963 | + | |
| 964 | + | |
| 965 | + | |
| 966 | + | |
| 967 | + | |
| 968 | + | |
| 969 | + | |
| 970 | + | |
| 971 | + | |
935 | 972 | | |
936 | 973 | | |
937 | 974 | | |
| |||
974 | 1011 | | |
975 | 1012 | | |
976 | 1013 | | |
977 | | - | |
978 | 1014 | | |
| 1015 | + | |
| 1016 | + | |
| 1017 | + | |
| 1018 | + | |
| 1019 | + | |
| 1020 | + | |
| 1021 | + | |
| 1022 | + | |
| 1023 | + | |
| 1024 | + | |
| 1025 | + | |
| 1026 | + | |
| 1027 | + | |
| 1028 | + | |
| 1029 | + | |
| 1030 | + | |
| 1031 | + | |
| 1032 | + | |
| 1033 | + | |
| 1034 | + | |
| 1035 | + | |
| 1036 | + | |
| 1037 | + | |
| 1038 | + | |
979 | 1039 | | |
980 | 1040 | | |
981 | 1041 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
133 | 133 | | |
134 | 134 | | |
135 | 135 | | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
136 | 152 | | |
137 | 153 | | |
138 | 154 | | |
| |||
0 commit comments