Bug 1976779 - rsclientcerts: make each backend responsible for rate-limiting calls to find_objects r=jschanck
Before this patch, `rsclientcerts::manager` would rate-limit calls to
`find_objects` to once every 3 seconds because the underlying operation can be
time-consuming (in particular, on macOS and Windows, if there are many
certificates/keys available). On Android, keys aren't available until the user
selects one, which means that if a call to `find_objects` happened before the
selection prompt was shown (which is what happens) and the user chose one in
less than 3 seconds, the backend wouldn't search again, thus making it seem like
no keys were available, which would cause Firefox to not send a client
certificate. This patch makes each backend implementation responsible for this
rate-limiting, because only they know if it's appropriate to do so (in particular,
on Android, `find_objects` doesn't have the same performance concern as
on macOS and Windows because rather than searching for certificates and
keys, it asks `ClientAuthCertificateManager` for the cached list of certificates
and keys that have already been approved for use by the user).
Differential Revision: https://phabricator.services.mozilla.com/D257065
<!DOCTYPE html><!-- Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/--><html><head><metacharset="utf-8"><title>CSS Test: 'object-fit: none' on video element, with a SVG image and with various 'object-position' values</title><linkrel="author"title="Daniel Holbert"href="mailto:dholbert@mozilla.com"><linkrel="help"href="http://www.w3.org/TR/css3-images/#sizing"><linkrel="help"href="http://www.w3.org/TR/css3-images/#the-object-fit"><linkrel="help"href="http://www.w3.org/TR/css3-images/#the-object-position"><linkrel="match"href="object-fit-none-svg-002-ref.html"><styletype="text/css">video{border:1pxdashedgray;padding:1px;object-fit:none;float:left;}.bigWide{width:48px;height:32px;}.bigTall{width:32px;height:48px;}.small{width:8px;height:8px;}br{clear:both;}.tr{object-position:topright}.bl{object-position:bottomleft}.tl{object-position:top25%left25%}.br{object-position:bottom1pxright2px}.tc{object-position:top3pxleft50%}.cr{object-position:top50%right25%}</style></head><body><!-- big/wide: --><videoposter="support/colors-8x16.svg"class="bigWide tr"></video><videoposter="support/colors-8x16.svg"class="bigWide bl"></video><videoposter="support/colors-8x16.svg"class="bigWide tl"></video><videoposter="support/colors-8x16.svg"class="bigWide br"></video><videoposter="support/colors-8x16.svg"class="bigWide tc"></video><videoposter="support/colors-8x16.svg"class="bigWide cr"></video><videoposter="support/colors-8x16.svg"class="bigWide"></video><br><!-- big/tall: --><videoposter="support/colors-8x16.svg"class="bigTall tr"></video><videoposter="support/colors-8x16.svg"class="bigTall bl"></video><videoposter="support/colors-8x16.svg"class="bigTall tl"></video><videoposter="support/colors-8x16.svg"class="bigTall br"></video><videoposter="support/colors-8x16.svg"class="bigTall tc"></video><videoposter="support/colors-8x16.svg"class="bigTall cr"></video><videoposter="support/colors-8x16.svg"class="bigTall"></video><br><!-- small: --><videoposter="support/colors-8x16.svg"class="small tr"></video><videoposter="support/colors-8x16.svg"class="small bl"></video><videoposter="support/colors-8x16.svg"class="small tl"></video><videoposter="support/colors-8x16.svg"class="small br"></video><videoposter="support/colors-8x16.svg"class="small tc"></video><videoposter="support/colors-8x16.svg"class="small cr"></video><videoposter="support/colors-8x16.svg"class="small"></video><br></body></html>