Skip to content

Latest commit

 

History

History
258 lines (224 loc) · 6.31 KB

mta-sts.md

File metadata and controls

258 lines (224 loc) · 6.31 KB

MTA-STS (text) records

Create

Create from constructor

$record = new MtaSts([
	'host' => "_mta-sts.bluelibraries.com",
	'ttl' => 3600,
	'txt' => "v=STSv1; id=test1234"
]);

echo 'getHost = ' . $record->getHost() . PHP_EOL;
echo 'getTtl = ' . $record->getTtl() . PHP_EOL;
echo 'getClass = ' . $record->getClass() . PHP_EOL;
echo 'getTypeName = ' . $record->getTypeName() . PHP_EOL;
echo 'getVersion = ' . $record->getVersion() . PHP_EOL;
echo 'getId = ' . $record->getId() . PHP_EOL;
echo 'getTxt = ' . $record->getTxt() . PHP_EOL;
getHost = _mta-sts.bluelibraries.com
getTtl = 3600
getClass = IN
getTypeName = MTA-STS-REPORTING
getVersion = STSv1
getId = test1234
getTxt = v=STSv1; id=test1234

Create with a setter

$record = new MtaSts();
                $record->setData([
	'host' => "_mta-sts.bluelibraries.com",
	'ttl' => 3600,
	'txt' => "v=STSv1; id=test1234"
]);

echo 'getHost = ' . $record->getHost() . PHP_EOL;
echo 'getTtl = ' . $record->getTtl() . PHP_EOL;
echo 'getClass = ' . $record->getClass() . PHP_EOL;
echo 'getTypeName = ' . $record->getTypeName() . PHP_EOL;
echo 'getVersion = ' . $record->getVersion() . PHP_EOL;
echo 'getId = ' . $record->getId() . PHP_EOL;
echo 'getTxt = ' . $record->getTxt() . PHP_EOL;
getHost = _mta-sts.bluelibraries.com
getTtl = 3600
getClass = IN
getTypeName = MTA-STS-REPORTING
getVersion = STSv1
getId = test1234
getTxt = v=STSv1; id=test1234

Create from string

$record = Record::fromString('_mta-sts.bluelibraries.com 3600 IN TXT "v=STSv1; id=test1234"');

echo 'getHost = ' . $record->getHost() . PHP_EOL;
echo 'getTtl = ' . $record->getTtl() . PHP_EOL;
echo 'getClass = ' . $record->getClass() . PHP_EOL;
echo 'getTypeName = ' . $record->getTypeName() . PHP_EOL;
echo 'getVersion = ' . $record->getVersion() . PHP_EOL;
echo 'getId = ' . $record->getId() . PHP_EOL;
echo 'getTxt = ' . $record->getTxt() . PHP_EOL;
getHost = _mta-sts.bluelibraries.com
getTtl = 3600
getClass = IN
getTypeName = MTA-STS-REPORTING
getVersion = STSv1
getId = test1234
getTxt = v=STSv1; id=test1234

Create from initialized array

$record = Record::fromNormalizedArray([
	'host' => "_mta-sts.bluelibraries.com",
	'ttl' => 3600,
	'txt' => "v=STSv1; id=test1234",
	'type' => "TXT"
]);

echo 'getHost = ' . $record->getHost() . PHP_EOL;
echo 'getTtl = ' . $record->getTtl() . PHP_EOL;
echo 'getClass = ' . $record->getClass() . PHP_EOL;
echo 'getTypeName = ' . $record->getTypeName() . PHP_EOL;
echo 'getVersion = ' . $record->getVersion() . PHP_EOL;
echo 'getId = ' . $record->getId() . PHP_EOL;
echo 'getTxt = ' . $record->getTxt() . PHP_EOL;
getHost = _mta-sts.bluelibraries.com
getTtl = 3600
getClass = IN
getTypeName = MTA-STS-REPORTING
getVersion = STSv1
getId = test1234
getTxt = v=STSv1; id=test1234

Retrieve from Internet

Retrieve with helper

$records = DNS::getRecords('_mta-sts.bluelibraries.com', RecordTypes::TXT);

print_r($records);
Array
(
    [0] => BlueLibraries\Dns\Records\Types\Txt\MtaSts Object
        (
            [txtRegex:BlueLibraries\Dns\Records\Types\Txt\MtaSts:private] => /^v=STSv1; id=([a-z0-9]+){1,32}$/i
            [data:protected] => Array
                (
                    [host] => _mta-sts.bluelibraries.com
                    [ttl] => 3600
                    [txt] => v=STSv1; id=test1234
                    [type] => TXT
                    [class] => IN
                )

            [parsedValues:BlueLibraries\Dns\Records\Types\Txt\MtaSts:private] => Array
                (
                )

        )

)

Retrieve without helper

$dns = new DnsRecords();
$records = $dns->get('_mta-sts.bluelibraries.com', RecordTypes::TXT);

print_r($records);
Array
(
    [0] => BlueLibraries\Dns\Records\Types\Txt\MtaSts Object
        (
            [txtRegex:BlueLibraries\Dns\Records\Types\Txt\MtaSts:private] => /^v=STSv1; id=([a-z0-9]+){1,32}$/i
            [data:protected] => Array
                (
                    [host] => _mta-sts.bluelibraries.com
                    [ttl] => 3600
                    [txt] => v=STSv1; id=test1234
                    [type] => TXT
                    [class] => IN
                )

            [parsedValues:BlueLibraries\Dns\Records\Types\Txt\MtaSts:private] => Array
                (
                )

        )

)

Retrieve without helper, using custom handler settings

$dnsHandler = new TCP();
$dnsHandler->setRetries(2);
$dnsHandler->setTimeout(3);
$dnsHandler->setNameserver('8.8.8.8');

$dns = new DnsRecords($dnsHandler);

$records = $dns->get('_mta-sts.bluelibraries.com', RecordTypes::TXT);

print_r($records);
Array
(
    [0] => BlueLibraries\Dns\Records\Types\Txt\MtaSts Object
        (
            [txtRegex:BlueLibraries\Dns\Records\Types\Txt\MtaSts:private] => /^v=STSv1; id=([a-z0-9]+){1,32}$/i
            [data:protected] => Array
                (
                    [host] => _mta-sts.bluelibraries.com
                    [ttl] => 3600
                    [txt] => v=STSv1; id=test1234
                    [type] => TXT
                    [class] => IN
                )

            [parsedValues:BlueLibraries\Dns\Records\Types\Txt\MtaSts:private] => Array
                (
                )

        )

)

Transform

Transform to String

$record = new MtaSts([
	'host' => "_mta-sts.bluelibraries.com",
	'ttl' => 3600,
	'txt' => "v=STSv1; id=test1234"
]);

echo 'string1 = ' . json_encode($record->toString()) . PHP_EOL;
echo 'string2 = ' . json_encode((string)$record) . PHP_EOL;
string1 = "_mta-sts.bluelibraries.com 3600 IN TXT \"v=STSv1; id=test1234\""
string2 = "_mta-sts.bluelibraries.com 3600 IN TXT \"v=STSv1; id=test1234\""

Transform to JSON

$record = new MtaSts([
	'host' => "_mta-sts.bluelibraries.com",
	'ttl' => 3600,
	'txt' => "v=STSv1; id=test1234"
]);

echo 'JSON = ' . json_encode($record) . PHP_EOL;
JSON = {"host":"_mta-sts.bluelibraries.com","ttl":3600,"txt":"v=STSv1; id=test1234","class":"IN","type":"TXT"}

Transform to Array

$record = new MtaSts([
	'host' => "_mta-sts.bluelibraries.com",
	'ttl' => 3600,
	'txt' => "v=STSv1; id=test1234"
]);

print_r($record->toArray());
Array
(
    [host] => _mta-sts.bluelibraries.com
    [ttl] => 3600
    [txt] => v=STSv1; id=test1234
    [class] => IN
    [type] => TXT
)