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><title>clip-path on inline, horizontal-tb writing-mode</title><linkrel="author"title="Morten Stenshorne"href="mstensho@chromium.org"><linkrel="help"href="https://www.w3.org/TR/css-masking-1/#the-clip-path"title="5.1 Clipping Shape: the clip-path property"><linkrel="match"href="../../reference/ref-filled-green-100px-square.xht"><metacontent="ahem"name="flags"><linkrel="stylesheet"type="text/css"href="/fonts/ahem.css"/><style>body{overflow:hidden;}.container{writing-mode:horizontal-tb;padding:70px30px;margin:-170px-230px;font:100px/1Ahem;line-height:100px;color:transparent;}.container>span{clip-path:polygon(0%0%,50%0%,50%100%,0%100%);color:red;}.container>span>span{color:green;}</style><p>Test passes if there is a filled green square and <strong>no red</strong>.</p><divclass="container"><br> XX<span><span>X</span>X<br>XXXXX</span></div>