With AirPrint, other Apple devices are able to find and use the printer WITHOUT NEEDING THE CERTIFICATE INSTALLED!
TLDR : AirPrint can probably simply use the provided TLS certificate for encryption without performing any trust checks
With mDNS your AirPrint printer will be discovered with a hostname brother-printer-model-number-xyz.local.
or whatever printer name gets assigned as a hostname in the .local
TLD.
That .local
domain is a special use domain name, which is not resolvable in the global Domain Name System. Everybody can use the .local
TLD within their own network.
One of the consequences is that there is no unique owner/operator of that domain. Since public Certificate Authorities can't identify an owner, they can't establish a chain of trust and CA's won't ever issue officially signed TLS certificates for the .local
domain. (Similar to how you can't get an official CA to issue a certificate for "localhost".)
Since there can never be a "valid" or "trusted" certificate issued to printers and other devices that can be discovered via multicast DNS (mDNS) and zero-configuration networking (zeroconf) they will always have self-signed certificate.see footnote
That can be dealt with in several possible ways I think.
One approach is to program your AirPrint driver to simply not care about trust, when the printer is discovered with .local
hostname and supports a TLS certificate; then simply accept and use that for encryption, without checking if that certificate can actually be trusted. You won't have the additional security features that TLS can provide, but regardless your print jobs will still be encrypted in transit and protected from eavesdropping.
Even with the trust policies set on the cert, Chrome still thinks connections to the printer are Not Secure.
As far as I know Chrome uses it's own internal CA trust and doesn't use the Apple/OSX Keychain.
For instance my (HP) printer's self-signed certificate is included in my keychain. Safari will happily connect to the web interface of that printer and when checking the certificate properties displays:
data:image/s3,"s3://crabby-images/cefb5/cefb5e5c3addff5ab2b65bee7460dcb764665c4f" alt="Safari trusts"
Chrome
Chrome on the same Mac the other hand is still showing large danger signs:
data:image/s3,"s3://crabby-images/679e0/679e0572f046d18bd5d413dc42d91c75ad50ebd9" alt="chrome warnings"
Footnote:
Technically when you operate your own internal CA, nothing prohibits you form issuing a signed certificate for the .local
hosts in your network.