| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 | <?php/* * This file is part of the Symfony package. * * (c) Fabien Potencier <fabien@symfony.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */namespace Symfony\Component\Mime\Encoder;use Symfony\Component\Mime\Exception\AddressEncoderException;/** * An IDN email address encoder. * * Encodes the domain part of an address using IDN. This is compatible will all * SMTP servers. * * This encoder does not support email addresses with non-ASCII characters in * local-part (the substring before @). * * @author Christian Schmidt */final class IdnAddressEncoder implements AddressEncoderInterface{    /**     * Encodes the domain part of an address using IDN.     *     * @throws AddressEncoderException If local-part contains non-ASCII characters     */    public function encodeString(string $address): string    {        $i = strrpos($address, '@');        if (false !== $i) {            $local = substr($address, 0, $i);            $domain = substr($address, $i + 1);            if (preg_match('/[^\x00-\x7F]/', $local)) {                throw new AddressEncoderException(sprintf('Non-ASCII characters not supported in local-part os "%s".', $address));            }            if (preg_match('/[^\x00-\x7F]/', $domain)) {                $address = sprintf('%s@%s', $local, idn_to_ascii($domain, \IDNA_DEFAULT | \IDNA_USE_STD3_RULES | \IDNA_CHECK_BIDI | \IDNA_CHECK_CONTEXTJ | \IDNA_NONTRANSITIONAL_TO_ASCII, \INTL_IDNA_VARIANT_UTS46));            }        }        return $address;    }}
 |