From a88895e1d0f2af0d3845deec14840034ff728504 Mon Sep 17 00:00:00 2001 From: Chris Wright Date: Mon, 15 May 2017 20:38:41 +0100 Subject: [PATCH 01/11] Change default to for Decoder::$allowTrailingData to true --- src/Decoder/Decoder.php | 2 +- src/Decoder/DecoderFactory.php | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Decoder/Decoder.php b/src/Decoder/Decoder.php index e8d32fe..1f2ca85 100644 --- a/src/Decoder/Decoder.php +++ b/src/Decoder/Decoder.php @@ -94,7 +94,7 @@ public function __construct( ResourceBuilder $resourceBuilder, TypeBuilder $typeBuilder, DecodingContextFactory $decodingContextFactory, - $allowTrailingData = false + $allowTrailingData = true ) { $this->packetFactory = $packetFactory; $this->messageFactory = $messageFactory; diff --git a/src/Decoder/DecoderFactory.php b/src/Decoder/DecoderFactory.php index b063667..242820b 100644 --- a/src/Decoder/DecoderFactory.php +++ b/src/Decoder/DecoderFactory.php @@ -43,7 +43,7 @@ class DecoderFactory * @param bool $allowTrailingData * @return Decoder */ - public function create(TypeDefinitionManager $typeDefinitionManager = null, $allowTrailingData = false) + public function create(TypeDefinitionManager $typeDefinitionManager = null, $allowTrailingData = true) { $typeBuilder = new TypeBuilder(new TypeFactory); From 30b215569488b33aeb0faf54efe9e6336abf1fa8 Mon Sep 17 00:00:00 2001 From: Chris Wright Date: Mon, 15 May 2017 20:45:12 +0100 Subject: [PATCH 02/11] Bump PHP version requirement to 7.0 and use strict types --- composer.json | 2 +- src/Decoder/Decoder.php | 2 +- src/Decoder/DecoderFactory.php | 2 +- src/Decoder/DecodingContext.php | 2 +- src/Decoder/DecodingContextFactory.php | 2 +- src/Encoder/Encoder.php | 2 +- src/Encoder/EncoderFactory.php | 2 +- src/Encoder/EncodingContext.php | 2 +- src/Encoder/EncodingContextFactory.php | 2 +- src/Enumeration.php | 2 +- src/Messages/Message.php | 2 +- src/Messages/MessageFactory.php | 2 +- src/Messages/MessageOpCodes.php | 2 +- src/Messages/MessageResponseCodes.php | 2 +- src/Messages/MessageTypes.php | 2 +- src/Packets/LabelRegistry.php | 2 +- src/Packets/Packet.php | 2 +- src/Packets/PacketFactory.php | 2 +- src/Records/Question.php | 2 +- src/Records/QuestionFactory.php | 2 +- src/Records/RData.php | 2 +- src/Records/RDataBuilder.php | 2 +- src/Records/RDataFactory.php | 2 +- src/Records/Record.php | 2 +- src/Records/RecordCollection.php | 2 +- src/Records/RecordCollectionFactory.php | 2 +- src/Records/RecordTypes.php | 2 +- src/Records/Resource.php | 2 +- src/Records/ResourceBuilder.php | 2 +- src/Records/ResourceBuilderFactory.php | 2 +- src/Records/ResourceClasses.php | 2 +- src/Records/ResourceFactory.php | 2 +- src/Records/ResourceQClasses.php | 2 +- src/Records/ResourceQTypes.php | 2 +- src/Records/ResourceTypes.php | 2 +- src/Records/TypeDefinitions/FieldDefinition.php | 2 +- src/Records/TypeDefinitions/FieldDefinitionFactory.php | 2 +- src/Records/TypeDefinitions/TypeDefinition.php | 2 +- src/Records/TypeDefinitions/TypeDefinitionFactory.php | 2 +- src/Records/TypeDefinitions/TypeDefinitionManager.php | 2 +- src/Records/TypeDefinitions/TypeDefinitionManagerFactory.php | 2 +- src/Records/Types/Anything.php | 2 +- src/Records/Types/BitMap.php | 2 +- src/Records/Types/Char.php | 2 +- src/Records/Types/CharacterString.php | 2 +- src/Records/Types/DomainName.php | 2 +- src/Records/Types/IPv4Address.php | 2 +- src/Records/Types/IPv6Address.php | 2 +- src/Records/Types/Long.php | 2 +- src/Records/Types/Short.php | 2 +- src/Records/Types/Type.php | 2 +- src/Records/Types/TypeBuilder.php | 2 +- src/Records/Types/TypeFactory.php | 2 +- src/Records/Types/Types.php | 2 +- 54 files changed, 54 insertions(+), 54 deletions(-) diff --git a/composer.json b/composer.json index 59200c4..6509ee1 100644 --- a/composer.json +++ b/composer.json @@ -4,7 +4,7 @@ "license": "MIT", "keywords": ["dns"], "require": { - "php": ">=5.4.0" + "php": ">=7.0" }, "autoload": { "psr-4": { diff --git a/src/Decoder/Decoder.php b/src/Decoder/Decoder.php index 1f2ca85..818a4cc 100644 --- a/src/Decoder/Decoder.php +++ b/src/Decoder/Decoder.php @@ -1,4 +1,4 @@ - Date: Mon, 15 May 2017 20:46:03 +0100 Subject: [PATCH 03/11] ctor refactor to silence inspections --- src/Records/Types/DomainName.php | 10 ++++------ src/Records/Types/IPv4Address.php | 10 ++++------ src/Records/Types/IPv6Address.php | 10 ++++------ 3 files changed, 12 insertions(+), 18 deletions(-) diff --git a/src/Records/Types/DomainName.php b/src/Records/Types/DomainName.php index a1a2f0a..5dc458c 100644 --- a/src/Records/Types/DomainName.php +++ b/src/Records/Types/DomainName.php @@ -42,12 +42,10 @@ class DomainName extends Type */ public function __construct($value = null) { - if (isset($value)) { - if (is_array($value)) { - $this->setLabels($value); - } else { - $this->setValue($value); - } + if (is_array($value)) { + $this->setLabels($value); + } else { + parent::__construct($value); } } diff --git a/src/Records/Types/IPv4Address.php b/src/Records/Types/IPv4Address.php index c6c8f09..fad4853 100644 --- a/src/Records/Types/IPv4Address.php +++ b/src/Records/Types/IPv4Address.php @@ -40,12 +40,10 @@ class IPv4Address extends Type */ public function __construct($value = null) { - if (isset($value)) { - if (is_array($value)) { - $this->setOctets($value); - } else { - $this->setValue($value); - } + if (is_array($value)) { + $this->setOctets($value); + } else { + parent::__construct($value); } } diff --git a/src/Records/Types/IPv6Address.php b/src/Records/Types/IPv6Address.php index 7000ad5..ac0f96f 100644 --- a/src/Records/Types/IPv6Address.php +++ b/src/Records/Types/IPv6Address.php @@ -91,12 +91,10 @@ private function createCompressedString($shorts) */ public function __construct($value = null) { - if (isset($value)) { - if (is_array($value)) { - $this->setShorts($value); - } else { - $this->setValue($value); - } + if (is_array($value)) { + $this->setShorts($value); + } else { + parent::__construct($value); } } From 4305ae8f20862394171c66e17e11216b28e5e5d8 Mon Sep 17 00:00:00 2001 From: Chris Wright Date: Mon, 15 May 2017 21:48:10 +0100 Subject: [PATCH 04/11] Scalar types, return types and function prefixes --- src/Decoder/Decoder.php | 73 ++++++++++--------- src/Decoder/DecoderFactory.php | 2 +- src/Decoder/DecodingContext.php | 28 +++---- src/Decoder/DecodingContextFactory.php | 2 +- src/Encoder/Encoder.php | 60 +++++++-------- src/Encoder/EncoderFactory.php | 2 +- src/Encoder/EncodingContext.php | 14 ++-- src/Encoder/EncodingContextFactory.php | 2 +- src/Enumeration.php | 4 +- src/Messages/Message.php | 59 +++++++-------- src/Messages/MessageFactory.php | 2 +- src/Messages/MessageOpCodes.php | 2 +- src/Messages/MessageResponseCodes.php | 2 +- src/Messages/MessageTypes.php | 2 +- src/Packets/LabelRegistry.php | 16 ++-- src/Packets/Packet.php | 23 +++--- src/Packets/PacketFactory.php | 2 +- src/Records/Question.php | 2 +- src/Records/QuestionFactory.php | 2 +- src/Records/RData.php | 34 ++++----- src/Records/RDataBuilder.php | 2 +- src/Records/RDataFactory.php | 2 +- src/Records/Record.php | 11 ++- src/Records/RecordCollection.php | 32 ++++---- src/Records/RecordCollectionFactory.php | 2 +- src/Records/RecordTypes.php | 2 +- src/Records/Resource.php | 9 +-- src/Records/ResourceBuilder.php | 2 +- src/Records/ResourceBuilderFactory.php | 2 +- src/Records/ResourceClasses.php | 2 +- src/Records/ResourceFactory.php | 2 +- src/Records/ResourceQClasses.php | 2 +- src/Records/ResourceQTypes.php | 2 +- src/Records/ResourceTypes.php | 2 +- .../TypeDefinitions/FieldDefinition.php | 24 +++--- .../FieldDefinitionFactory.php | 2 +- .../TypeDefinitions/TypeDefinition.php | 29 ++++---- .../TypeDefinitions/TypeDefinitionFactory.php | 2 +- .../TypeDefinitions/TypeDefinitionManager.php | 12 ++- .../TypeDefinitionManagerFactory.php | 2 +- src/Records/Types/Anything.php | 5 +- src/Records/Types/BitMap.php | 12 +-- src/Records/Types/Char.php | 5 +- src/Records/Types/CharacterString.php | 5 +- src/Records/Types/DomainName.php | 16 ++-- src/Records/Types/IPv4Address.php | 16 ++-- src/Records/Types/IPv6Address.php | 32 ++++---- src/Records/Types/Long.php | 7 +- src/Records/Types/Short.php | 7 +- src/Records/Types/Type.php | 12 +-- src/Records/Types/TypeBuilder.php | 2 +- src/Records/Types/TypeFactory.php | 22 +++--- src/Records/Types/Types.php | 2 +- 53 files changed, 307 insertions(+), 314 deletions(-) diff --git a/src/Decoder/Decoder.php b/src/Decoder/Decoder.php index 818a4cc..28e743f 100644 --- a/src/Decoder/Decoder.php +++ b/src/Decoder/Decoder.php @@ -17,6 +17,7 @@ use \LibDNS\Packets\Packet; use \LibDNS\Messages\MessageFactory; use \LibDNS\Messages\Message; +use LibDNS\Records\Question; use \LibDNS\Records\QuestionFactory; use \LibDNS\Records\ResourceBuilder; use \LibDNS\Records\Types\Type; @@ -94,7 +95,7 @@ public function __construct( ResourceBuilder $resourceBuilder, TypeBuilder $typeBuilder, DecodingContextFactory $decodingContextFactory, - $allowTrailingData = true + bool $allowTrailingData = true ) { $this->packetFactory = $packetFactory; $this->messageFactory = $messageFactory; @@ -113,7 +114,7 @@ public function __construct( * @return string * @throws \UnexpectedValueException When the read operation does not result in the requested number of bytes */ - private function readDataFromPacket(Packet $packet, $length) + private function readDataFromPacket(Packet $packet, int $length): string { if ($packet->getBytesRemaining() < $length) { throw new \UnexpectedValueException('Decode error: Incomplete packet (tried to read ' . $length . ' bytes from index ' . $packet->getPointer()); @@ -131,7 +132,7 @@ private function readDataFromPacket(Packet $packet, $length) */ private function decodeHeader(DecodingContext $decodingContext, Message $message) { - $header = unpack('nid/nmeta/nqd/nan/nns/nar', $this->readDataFromPacket($decodingContext->getPacket(), 12)); + $header = \unpack('nid/nmeta/nqd/nan/nns/nar', $this->readDataFromPacket($decodingContext->getPacket(), 12)); if (!$header) { throw new \UnexpectedValueException('Decode error: Header unpack failed'); } @@ -140,10 +141,10 @@ private function decodeHeader(DecodingContext $decodingContext, Message $message $message->setType(($header['meta'] & 0b1000000000000000) >> 15); $message->setOpCode(($header['meta'] & 0b0111100000000000) >> 11); - $message->isAuthoritative(($header['meta'] & 0b0000010000000000) >> 10); - $message->isTruncated(($header['meta'] & 0b0000001000000000) >> 9); - $message->isRecursionDesired(($header['meta'] & 0b0000000100000000) >> 8); - $message->isRecursionAvailable(($header['meta'] & 0b0000000010000000) >> 7); + $message->isAuthoritative((bool)(($header['meta'] & 0b0000010000000000) >> 10)); + $message->isTruncated((bool)(($header['meta'] & 0b0000001000000000) >> 9)); + $message->isRecursionDesired((bool)(($header['meta'] & 0b0000000100000000) >> 8)); + $message->isRecursionAvailable((bool)(($header['meta'] & 0b0000000010000000) >> 7)); $message->setResponseCode($header['meta'] & 0b0000000000001111); $decodingContext->setExpectedQuestionRecords($header['qd']); @@ -161,7 +162,7 @@ private function decodeHeader(DecodingContext $decodingContext, Message $message * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeAnything(DecodingContext $decodingContext, Anything $anything, $length) + private function decodeAnything(DecodingContext $decodingContext, Anything $anything, int $length): int { $anything->setValue($this->readDataFromPacket($decodingContext->getPacket(), $length)); @@ -177,7 +178,7 @@ private function decodeAnything(DecodingContext $decodingContext, Anything $anyt * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeBitMap(DecodingContext $decodingContext, BitMap $bitMap, $length) + private function decodeBitMap(DecodingContext $decodingContext, BitMap $bitMap, int $length): int { $bitMap->setValue($this->readDataFromPacket($decodingContext->getPacket(), $length)); @@ -192,9 +193,9 @@ private function decodeBitMap(DecodingContext $decodingContext, BitMap $bitMap, * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeChar(DecodingContext $decodingContext, Char $char) + private function decodeChar(DecodingContext $decodingContext, Char $char): int { - $value = unpack('C', $this->readDataFromPacket($decodingContext->getPacket(), 1))[1]; + $value = \unpack('C', $this->readDataFromPacket($decodingContext->getPacket(), 1))[1]; $char->setValue($value); return 1; @@ -208,10 +209,10 @@ private function decodeChar(DecodingContext $decodingContext, Char $char) * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeCharacterString(DecodingContext $decodingContext, CharacterString $characterString) + private function decodeCharacterString(DecodingContext $decodingContext, CharacterString $characterString): int { $packet = $decodingContext->getPacket(); - $length = ord($this->readDataFromPacket($packet, 1)); + $length = \ord($this->readDataFromPacket($packet, 1)); $characterString->setValue($this->readDataFromPacket($packet, $length)); return $length + 1; @@ -225,32 +226,32 @@ private function decodeCharacterString(DecodingContext $decodingContext, Charact * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeDomainName(DecodingContext $decodingContext, DomainName $domainName) + private function decodeDomainName(DecodingContext $decodingContext, DomainName $domainName): int { $packet = $decodingContext->getPacket(); - $startIndex = '0x' . dechex($packet->getPointer()); + $startIndex = '0x' . \dechex($packet->getPointer()); $labelRegistry = $decodingContext->getLabelRegistry(); $labels = []; $totalLength = 0; - while (++$totalLength && $length = ord($this->readDataFromPacket($packet, 1))) { + while (++$totalLength && $length = \ord($this->readDataFromPacket($packet, 1))) { $labelType = $length & 0b11000000; if ($labelType === 0b00000000) { $index = $packet->getPointer() - 1; $label = $this->readDataFromPacket($packet, $length); - array_unshift($labels, [$index, $label]); + \array_unshift($labels, [$index, $label]); $totalLength += $length; } else if ($labelType === 0b11000000) { - $index = (($length & 0b00111111) << 8) | ord($this->readDataFromPacket($packet, 1)); + $index = (($length & 0b00111111) << 8) | \ord($this->readDataFromPacket($packet, 1)); $ref = $labelRegistry->lookupLabel($index); if ($ref === null) { throw new \UnexpectedValueException('Decode error: Invalid compression pointer reference in domain name at position ' . $startIndex); } - array_unshift($labels, $ref); + \array_unshift($labels, $ref); $totalLength++; break; @@ -265,8 +266,8 @@ private function decodeDomainName(DecodingContext $decodingContext, DomainName $ $result = []; foreach ($labels as $label) { - if (is_int($label[0])) { - array_unshift($result, $label[1]); + if (\is_int($label[0])) { + \array_unshift($result, $label[1]); $labelRegistry->register($result, $label[0]); } else { $result = $label; @@ -285,9 +286,9 @@ private function decodeDomainName(DecodingContext $decodingContext, DomainName $ * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeIPv4Address(DecodingContext $decodingContext, IPv4Address $ipv4Address) + private function decodeIPv4Address(DecodingContext $decodingContext, IPv4Address $ipv4Address): int { - $octets = unpack('C4', $this->readDataFromPacket($decodingContext->getPacket(), 4)); + $octets = \unpack('C4', $this->readDataFromPacket($decodingContext->getPacket(), 4)); $ipv4Address->setOctets($octets); return 4; @@ -301,9 +302,9 @@ private function decodeIPv4Address(DecodingContext $decodingContext, IPv4Address * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeIPv6Address(DecodingContext $decodingContext, IPv6Address $ipv6Address) + private function decodeIPv6Address(DecodingContext $decodingContext, IPv6Address $ipv6Address): int { - $shorts = unpack('n8', $this->readDataFromPacket($decodingContext->getPacket(), 16)); + $shorts = \unpack('n8', $this->readDataFromPacket($decodingContext->getPacket(), 16)); $ipv6Address->setShorts($shorts); return 16; @@ -317,9 +318,9 @@ private function decodeIPv6Address(DecodingContext $decodingContext, IPv6Address * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeLong(DecodingContext $decodingContext, Long $long) + private function decodeLong(DecodingContext $decodingContext, Long $long): int { - $value = unpack('N', $this->readDataFromPacket($decodingContext->getPacket(), 4))[1]; + $value = \unpack('N', $this->readDataFromPacket($decodingContext->getPacket(), 4))[1]; $long->setValue($value); return 4; @@ -333,9 +334,9 @@ private function decodeLong(DecodingContext $decodingContext, Long $long) * @return int The number of packet bytes consumed by the operation * @throws \UnexpectedValueException When the packet data is invalid */ - private function decodeShort(DecodingContext $decodingContext, Short $short) + private function decodeShort(DecodingContext $decodingContext, Short $short): int { - $value = unpack('n', $this->readDataFromPacket($decodingContext->getPacket(), 2))[1]; + $value = \unpack('n', $this->readDataFromPacket($decodingContext->getPacket(), 2))[1]; $short->setValue($value); return 2; @@ -351,7 +352,7 @@ private function decodeShort(DecodingContext $decodingContext, Short $short) * @throws \UnexpectedValueException When the packet data is invalid * @throws \InvalidArgumentException When the Type subtype is unknown */ - private function decodeType(DecodingContext $decodingContext, Type $type, $length) + private function decodeType(DecodingContext $decodingContext, Type $type, int $length): int { if ($type instanceof Anything) { $result = $this->decodeAnything($decodingContext, $type, $length); @@ -372,7 +373,7 @@ private function decodeType(DecodingContext $decodingContext, Type $type, $lengt } else if ($type instanceof Short) { $result = $this->decodeShort($decodingContext, $type); } else { - throw new \InvalidArgumentException('Unknown Type ' . get_class($type)); + throw new \InvalidArgumentException('Unknown Type ' . \get_class($type)); } return $result; @@ -385,12 +386,12 @@ private function decodeType(DecodingContext $decodingContext, Type $type, $lengt * @return \LibDNS\Records\Question * @throws \UnexpectedValueException When the record is invalid */ - private function decodeQuestionRecord(DecodingContext $decodingContext) + private function decodeQuestionRecord(DecodingContext $decodingContext): Question { /** @var \LibDNS\Records\Types\DomainName $domainName */ $domainName = $this->typeBuilder->build(Types::DOMAIN_NAME); $this->decodeDomainName($decodingContext, $domainName); - $meta = unpack('ntype/nclass', $this->readDataFromPacket($decodingContext->getPacket(), 4)); + $meta = \unpack('ntype/nclass', $this->readDataFromPacket($decodingContext->getPacket(), 4)); $question = $this->questionFactory->create($meta['type']); $question->setName($domainName); @@ -407,12 +408,12 @@ private function decodeQuestionRecord(DecodingContext $decodingContext) * @throws \UnexpectedValueException When the record is invalid * @throws \InvalidArgumentException When a type subtype is unknown */ - private function decodeResourceRecord(DecodingContext $decodingContext) + private function decodeResourceRecord(DecodingContext $decodingContext): Resource { /** @var \LibDNS\Records\Types\DomainName $domainName */ $domainName = $this->typeBuilder->build(Types::DOMAIN_NAME); $this->decodeDomainName($decodingContext, $domainName); - $meta = unpack('ntype/nclass/Nttl/nlength', $this->readDataFromPacket($decodingContext->getPacket(), 10)); + $meta = \unpack('ntype/nclass/Nttl/nlength', $this->readDataFromPacket($decodingContext->getPacket(), 10)); $resource = $this->resourceBuilder->build($meta['type']); $resource->setName($domainName); @@ -452,7 +453,7 @@ private function decodeResourceRecord(DecodingContext $decodingContext) * @throws \UnexpectedValueException When the packet data is invalid * @throws \InvalidArgumentException When a type subtype is unknown */ - public function decode($data) + public function decode(string $data): Message { $packet = $this->packetFactory->create($data); $decodingContext = $this->decodingContextFactory->create($packet); diff --git a/src/Decoder/DecoderFactory.php b/src/Decoder/DecoderFactory.php index 2a9a525..0e6e58e 100644 --- a/src/Decoder/DecoderFactory.php +++ b/src/Decoder/DecoderFactory.php @@ -43,7 +43,7 @@ class DecoderFactory * @param bool $allowTrailingData * @return Decoder */ - public function create(TypeDefinitionManager $typeDefinitionManager = null, $allowTrailingData = true) + public function create(TypeDefinitionManager $typeDefinitionManager = null, bool $allowTrailingData = true): Decoder { $typeBuilder = new TypeBuilder(new TypeFactory); diff --git a/src/Decoder/DecodingContext.php b/src/Decoder/DecodingContext.php index 071a6d4..817aef2 100644 --- a/src/Decoder/DecodingContext.php +++ b/src/Decoder/DecodingContext.php @@ -72,7 +72,7 @@ public function __construct(Packet $packet, LabelRegistry $labelRegistry) * * @return \LibDNS\Packets\Packet */ - public function getPacket() + public function getPacket(): Packet { return $this->packet; } @@ -82,7 +82,7 @@ public function getPacket() * * @return \LibDNS\Packets\LabelRegistry */ - public function getLabelRegistry() + public function getLabelRegistry(): LabelRegistry { return $this->labelRegistry; } @@ -92,7 +92,7 @@ public function getLabelRegistry() * * @return int */ - public function getExpectedQuestionRecords() + public function getExpectedQuestionRecords(): int { return $this->expectedQuestionRecords; } @@ -102,9 +102,9 @@ public function getExpectedQuestionRecords() * * @param int $expectedQuestionRecords */ - public function setExpectedQuestionRecords($expectedQuestionRecords) + public function setExpectedQuestionRecords(int $expectedQuestionRecords) { - $this->expectedQuestionRecords = (int) $expectedQuestionRecords; + $this->expectedQuestionRecords = $expectedQuestionRecords; } /** @@ -112,7 +112,7 @@ public function setExpectedQuestionRecords($expectedQuestionRecords) * * @return int */ - public function getExpectedAnswerRecords() + public function getExpectedAnswerRecords(): int { return $this->expectedAnswerRecords; } @@ -122,9 +122,9 @@ public function getExpectedAnswerRecords() * * @param int $expectedAnswerRecords */ - public function setExpectedAnswerRecords($expectedAnswerRecords) + public function setExpectedAnswerRecords(int $expectedAnswerRecords) { - $this->expectedAnswerRecords = (int) $expectedAnswerRecords; + $this->expectedAnswerRecords = $expectedAnswerRecords; } /** @@ -132,7 +132,7 @@ public function setExpectedAnswerRecords($expectedAnswerRecords) * * @return int */ - public function getExpectedAuthorityRecords() + public function getExpectedAuthorityRecords(): int { return $this->expectedAuthorityRecords; } @@ -142,9 +142,9 @@ public function getExpectedAuthorityRecords() * * @param int $expectedAuthorityRecords */ - public function setExpectedAuthorityRecords($expectedAuthorityRecords) + public function setExpectedAuthorityRecords(int $expectedAuthorityRecords) { - $this->expectedAuthorityRecords = (int) $expectedAuthorityRecords; + $this->expectedAuthorityRecords = $expectedAuthorityRecords; } /** @@ -152,7 +152,7 @@ public function setExpectedAuthorityRecords($expectedAuthorityRecords) * * @return int */ - public function getExpectedAdditionalRecords() + public function getExpectedAdditionalRecords(): int { return $this->expectedAdditionalRecords; } @@ -162,8 +162,8 @@ public function getExpectedAdditionalRecords() * * @param int $expectedAdditionalRecords */ - public function setExpectedAdditionalRecords($expectedAdditionalRecords) + public function setExpectedAdditionalRecords(int $expectedAdditionalRecords) { - $this->expectedAdditionalRecords = (int) $expectedAdditionalRecords; + $this->expectedAdditionalRecords = $expectedAdditionalRecords; } } diff --git a/src/Decoder/DecodingContextFactory.php b/src/Decoder/DecodingContextFactory.php index 543e496..129860f 100644 --- a/src/Decoder/DecodingContextFactory.php +++ b/src/Decoder/DecodingContextFactory.php @@ -31,7 +31,7 @@ class DecodingContextFactory * @param \LibDNS\Packets\Packet $packet The packet to be decoded * @return \LibDNS\Decoder\DecodingContext */ - public function create(Packet $packet) + public function create(Packet $packet): DecodingContext { return new DecodingContext($packet, new LabelRegistry); } diff --git a/src/Encoder/Encoder.php b/src/Encoder/Encoder.php index 7188a0f..fae7ad8 100644 --- a/src/Encoder/Encoder.php +++ b/src/Encoder/Encoder.php @@ -67,7 +67,7 @@ public function __construct(PacketFactory $packetFactory, EncodingContextFactory * @return string * @throws \UnexpectedValueException When the header section is invalid */ - private function encodeHeader(EncodingContext $encodingContext, Message $message) + private function encodeHeader(EncodingContext $encodingContext, Message $message): string { $header = [ 'id' => $message->getID(), @@ -86,7 +86,7 @@ private function encodeHeader(EncodingContext $encodingContext, Message $message $header['meta'] |= ((int) $message->isRecursionAvailable()) << 7; $header['meta'] |= $message->getResponseCode(); - return pack('n*', $header['id'], $header['meta'], $header['qd'], $header['an'], $header['ns'], $header['ar']); + return \pack('n*', $header['id'], $header['meta'], $header['qd'], $header['an'], $header['ns'], $header['ar']); } /** @@ -95,7 +95,7 @@ private function encodeHeader(EncodingContext $encodingContext, Message $message * @param \LibDNS\Records\Types\Anything $anything * @return string */ - private function encodeAnything(Anything $anything) + private function encodeAnything(Anything $anything): string { return $anything->getValue(); } @@ -106,7 +106,7 @@ private function encodeAnything(Anything $anything) * @param \LibDNS\Records\Types\BitMap $bitMap * @return string */ - private function encodeBitMap(BitMap $bitMap) + private function encodeBitMap(BitMap $bitMap): string { return $bitMap->getValue(); } @@ -117,9 +117,9 @@ private function encodeBitMap(BitMap $bitMap) * @param \LibDNS\Records\Types\Char $char * @return string */ - private function encodeChar(Char $char) + private function encodeChar(Char $char): string { - return chr($char->getValue()); + return \chr($char->getValue()); } /** @@ -128,10 +128,10 @@ private function encodeChar(Char $char) * @param \LibDNS\Records\Types\CharacterString $characterString * @return string */ - private function encodeCharacterString(CharacterString $characterString) + private function encodeCharacterString(CharacterString $characterString): string { $data = $characterString->getValue(); - return chr(strlen($data)) . $data; + return \chr(\strlen($data)) . $data; } /** @@ -141,7 +141,7 @@ private function encodeCharacterString(CharacterString $characterString) * @param \LibDNS\Encoder\EncodingContext $encodingContext * @return string */ - private function encodeDomainName(DomainName $domainName, EncodingContext $encodingContext) + private function encodeDomainName(DomainName $domainName, EncodingContext $encodingContext): string { $packetIndex = $encodingContext->getPacket()->getLength() + 12; $labelRegistry = $encodingContext->getLabelRegistry(); @@ -151,19 +151,19 @@ private function encodeDomainName(DomainName $domainName, EncodingContext $encod if ($encodingContext->useCompression()) { do { - $part = implode('.', $labels); + $part = \implode('.', $labels); $index = $labelRegistry->lookupIndex($part); if ($index === null) { $labelRegistry->register($part, $packetIndex); - $label = array_shift($labels); - $length = strlen($label); + $label = \array_shift($labels); + $length = \strlen($label); - $result .= chr($length) . $label; + $result .= \chr($length) . $label; $packetIndex += $length + 1; } else { - $result .= pack('n', 0b1100000000000000 | $index); + $result .= \pack('n', 0b1100000000000000 | $index); break; } } while($labels); @@ -173,7 +173,7 @@ private function encodeDomainName(DomainName $domainName, EncodingContext $encod } } else { foreach ($labels as $label) { - $result .= chr(strlen($label)) . $label; + $result .= \chr(\strlen($label)) . $label; } $result .= "\x00"; @@ -188,10 +188,10 @@ private function encodeDomainName(DomainName $domainName, EncodingContext $encod * @param \LibDNS\Records\Types\IPv4Address $ipv4Address * @return string */ - private function encodeIPv4Address(IPv4Address $ipv4Address) + private function encodeIPv4Address(IPv4Address $ipv4Address): string { $octets = $ipv4Address->getOctets(); - return pack('C*', $octets[0], $octets[1], $octets[2], $octets[3]); + return \pack('C*', $octets[0], $octets[1], $octets[2], $octets[3]); } /** @@ -200,10 +200,10 @@ private function encodeIPv4Address(IPv4Address $ipv4Address) * @param \LibDNS\Records\Types\IPv6Address $ipv6Address * @return string */ - private function encodeIPv6Address(IPv6Address $ipv6Address) + private function encodeIPv6Address(IPv6Address $ipv6Address): string { $shorts = $ipv6Address->getShorts(); - return pack('n*', $shorts[0], $shorts[1], $shorts[2], $shorts[3], $shorts[4], $shorts[5], $shorts[6], $shorts[7]); + return \pack('n*', $shorts[0], $shorts[1], $shorts[2], $shorts[3], $shorts[4], $shorts[5], $shorts[6], $shorts[7]); } /** @@ -212,9 +212,9 @@ private function encodeIPv6Address(IPv6Address $ipv6Address) * @param \LibDNS\Records\Types\Long $long * @return string */ - private function encodeLong(Long $long) + private function encodeLong(Long $long): string { - return pack('N', $long->getValue()); + return \pack('N', $long->getValue()); } /** @@ -223,9 +223,9 @@ private function encodeLong(Long $long) * @param \LibDNS\Records\Types\Short $short * @return string */ - private function encodeShort(Short $short) + private function encodeShort(Short $short): string { - return pack('n', $short->getValue()); + return \pack('n', $short->getValue()); } /** @@ -235,7 +235,7 @@ private function encodeShort(Short $short) * @param \LibDNS\Records\Types\Type $type * @return string */ - private function encodeType(EncodingContext $encodingContext, Type $type) + private function encodeType(EncodingContext $encodingContext, Type $type): string { if ($type instanceof Anything) { $result = $this->encodeAnything($type); @@ -256,7 +256,7 @@ private function encodeType(EncodingContext $encodingContext, Type $type) } else if ($type instanceof Short) { $result = $this->encodeShort($type); } else { - throw new \InvalidArgumentException('Unknown Type ' . get_class($type)); + throw new \InvalidArgumentException('Unknown Type ' . \get_class($type)); } return $result; @@ -273,9 +273,9 @@ private function encodeQuestionRecord(EncodingContext $encodingContext, Question if (!$encodingContext->isTruncated()) { $packet = $encodingContext->getPacket(); $name = $this->encodeDomainName($record->getName(), $encodingContext); - $meta = pack('n*', $record->getType(), $record->getClass()); + $meta = \pack('n*', $record->getType(), $record->getClass()); - if (12 + $packet->getLength() + strlen($name) + 4 > 512) { + if (12 + $packet->getLength() + \strlen($name) + 4 > 512) { $encodingContext->isTruncated(true); } else { $packet->write($name); @@ -301,9 +301,9 @@ private function encodeResourceRecord(EncodingContext $encodingContext, Resource $data .= $this->encodeType($encodingContext, $field); } - $meta = pack('n2Nn', $record->getType(), $record->getClass(), $record->getTTL(), strlen($data)); + $meta = \pack('n2Nn', $record->getType(), $record->getClass(), $record->getTTL(), \strlen($data)); - if (12 + $packet->getLength() + strlen($name) + 10 + strlen($data) > 512) { + if (12 + $packet->getLength() + \strlen($name) + 10 + \strlen($data) > 512) { $encodingContext->isTruncated(true); } else { $packet->write($name); @@ -320,7 +320,7 @@ private function encodeResourceRecord(EncodingContext $encodingContext, Resource * @param bool $compress Enable message compression * @return string */ - public function encode(Message $message, $compress = true) + public function encode(Message $message, $compress = true): string { $packet = $this->packetFactory->create(); $encodingContext = $this->encodingContextFactory->create($packet, $compress); diff --git a/src/Encoder/EncoderFactory.php b/src/Encoder/EncoderFactory.php index dbeec43..5bd73f8 100644 --- a/src/Encoder/EncoderFactory.php +++ b/src/Encoder/EncoderFactory.php @@ -29,7 +29,7 @@ class EncoderFactory * * @return \LibDNS\Encoder\Encoder */ - public function create() + public function create(): Encoder { return new Encoder(new PacketFactory, new EncodingContextFactory); } diff --git a/src/Encoder/EncodingContext.php b/src/Encoder/EncodingContext.php index 302686c..ec862e7 100644 --- a/src/Encoder/EncodingContext.php +++ b/src/Encoder/EncodingContext.php @@ -52,11 +52,11 @@ class EncodingContext * @param \LibDNS\Packets\LabelRegistry $labelRegistry * @param bool $compress */ - public function __construct(Packet $packet, LabelRegistry $labelRegistry, $compress) + public function __construct(Packet $packet, LabelRegistry $labelRegistry, bool $compress) { $this->packet = $packet; $this->labelRegistry = $labelRegistry; - $this->compress = (bool) $compress; + $this->compress = $compress; } /** @@ -64,7 +64,7 @@ public function __construct(Packet $packet, LabelRegistry $labelRegistry, $compr * * @return \LibDNS\Packets\Packet */ - public function getPacket() + public function getPacket(): Packet { return $this->packet; } @@ -74,7 +74,7 @@ public function getPacket() * * @return \LibDNS\Packets\LabelRegistry */ - public function getLabelRegistry() + public function getLabelRegistry(): LabelRegistry { return $this->labelRegistry; } @@ -84,7 +84,7 @@ public function getLabelRegistry() * * @return bool */ - public function useCompression() + public function useCompression(): bool { return $this->compress; } @@ -95,12 +95,12 @@ public function useCompression() * @param bool $truncate * @return bool */ - public function isTruncated($truncate = null) + public function isTruncated(bool $truncate = null): bool { $result = $this->truncate; if ($truncate !== null) { - $this->truncate = (bool) $truncate; + $this->truncate = $truncate; } return $result; diff --git a/src/Encoder/EncodingContextFactory.php b/src/Encoder/EncodingContextFactory.php index 16d8520..8642385 100644 --- a/src/Encoder/EncodingContextFactory.php +++ b/src/Encoder/EncodingContextFactory.php @@ -32,7 +32,7 @@ class EncodingContextFactory * @param bool $compress Whether message compression is enabled * @return \LibDNS\Encoder\EncodingContext */ - public function create(Packet $packet, $compress) + public function create(Packet $packet, bool $compress): EncodingContext { return new EncodingContext($packet, new LabelRegistry, $compress); } diff --git a/src/Enumeration.php b/src/Enumeration.php index 50d88b3..402e0c2 100644 --- a/src/Enumeration.php +++ b/src/Enumeration.php @@ -20,9 +20,9 @@ * @package LibDNS * @author Chris Wright */ -class Enumeration +abstract class Enumeration { - final public function __construct() + final protected function __construct() { throw new \LogicException('Enumerations cannot be instantiated'); } diff --git a/src/Messages/Message.php b/src/Messages/Message.php index d8f8f76..673ae3e 100644 --- a/src/Messages/Message.php +++ b/src/Messages/Message.php @@ -13,6 +13,7 @@ */ namespace LibDNS\Messages; +use LibDNS\Records\RecordCollection; use \LibDNS\Records\RecordCollectionFactory; use \LibDNS\Records\RecordTypes; @@ -33,7 +34,7 @@ class Message /** * @var int Indicates the type of the message, can be indicated using the MessageTypes enum */ - private $type; + private $type = -1; /** * @var int Message opcode, can be indicated using the MessageOpCodes enum @@ -48,7 +49,7 @@ class Message /** * @var bool Whether the message is truncated */ - private $truncated; + private $truncated = false; /** * @var bool Whether a query desires the server to recurse the lookup @@ -92,7 +93,7 @@ class Message * @param int $type Value of the message type field * @throws \RangeException When the supplied message type is outside the valid range 0 - 1 */ - public function __construct(RecordCollectionFactory $recordCollectionFactory, $type = null) + public function __construct(RecordCollectionFactory $recordCollectionFactory, int $type = null) { $this->questionRecords = $recordCollectionFactory->create(RecordTypes::QUESTION); $this->answerRecords = $recordCollectionFactory->create(RecordTypes::RESOURCE); @@ -109,7 +110,7 @@ public function __construct(RecordCollectionFactory $recordCollectionFactory, $t * * @return int */ - public function getID() + public function getID(): int { return $this->id; } @@ -120,9 +121,8 @@ public function getID() * @param int $id The new value * @throws \RangeException When the supplied value is outside the valid range 0 - 65535 */ - public function setID($id) + public function setID(int $id) { - $id = (int) $id; if ($id < 0 || $id > 65535) { throw new \RangeException('Message ID must be in the range 0 - 65535'); } @@ -135,7 +135,7 @@ public function setID($id) * * @return int */ - public function getType() + public function getType(): int { return $this->type; } @@ -146,9 +146,8 @@ public function getType() * @param int $type The new value * @throws \RangeException When the supplied value is outside the valid range 0 - 1 */ - public function setType($type) + public function setType(int $type) { - $type = (int) $type; if ($type < 0 || $type > 1) { throw new \RangeException('Message type must be in the range 0 - 1'); } @@ -161,7 +160,7 @@ public function setType($type) * * @return int */ - public function getOpCode() + public function getOpCode(): int { return $this->opCode; } @@ -172,9 +171,8 @@ public function getOpCode() * @param int $opCode The new value * @throws \RangeException When the supplied value is outside the valid range 0 - 15 */ - public function setOpCode($opCode) + public function setOpCode(int $opCode) { - $opCode = (int) $opCode; if ($opCode < 0 || $opCode > 15) { throw new \RangeException('Message opcode must be in the range 0 - 15'); } @@ -188,15 +186,15 @@ public function setOpCode($opCode) * @param bool $newValue The new value * @return bool The old value */ - public function isAuthoritative($newValue = null) + public function isAuthoritative(bool $newValue = null): bool { $result = $this->authoritative; if ($newValue !== null) { - $this->authoritative = (bool) $newValue; + $this->authoritative = $newValue; } - return (bool) $result; + return $result; } /** @@ -205,15 +203,15 @@ public function isAuthoritative($newValue = null) * @param bool $newValue The new value * @return bool The old value */ - public function isTruncated($newValue = null) + public function isTruncated(bool $newValue = null): bool { $result = $this->truncated; if ($newValue !== null) { - $this->truncated = (bool) $newValue; + $this->truncated = $newValue; } - return (bool) $result; + return $result; } /** @@ -222,15 +220,15 @@ public function isTruncated($newValue = null) * @param bool $newValue The new value * @return bool The old value */ - public function isRecursionDesired($newValue = null) + public function isRecursionDesired(bool $newValue = null): bool { $result = $this->recursionDesired; if ($newValue !== null) { - $this->recursionDesired = (bool) $newValue; + $this->recursionDesired = $newValue; } - return (bool) $result; + return $result; } /** @@ -239,15 +237,15 @@ public function isRecursionDesired($newValue = null) * @param bool $newValue The new value * @return bool The old value */ - public function isRecursionAvailable($newValue = null) + public function isRecursionAvailable(bool $newValue = null): bool { $result = $this->recursionAvailable; if ($newValue !== null) { - $this->recursionAvailable = (bool) $newValue; + $this->recursionAvailable = $newValue; } - return (bool) $result; + return $result; } /** @@ -255,7 +253,7 @@ public function isRecursionAvailable($newValue = null) * * @return int */ - public function getResponseCode() + public function getResponseCode(): int { return $this->opCode; } @@ -266,9 +264,8 @@ public function getResponseCode() * @param int $responseCode The new value * @throws \RangeException When the supplied value is outside the valid range 0 - 15 */ - public function setResponseCode($responseCode) + public function setResponseCode(int $responseCode) { - $responseCode = (int) $responseCode; if ($responseCode < 0 || $responseCode > 15) { throw new \RangeException('Message response code must be in the range 0 - 15'); } @@ -281,7 +278,7 @@ public function setResponseCode($responseCode) * * @return \LibDNS\Records\RecordCollection */ - public function getQuestionRecords() + public function getQuestionRecords(): RecordCollection { return $this->questionRecords; } @@ -291,7 +288,7 @@ public function getQuestionRecords() * * @return \LibDNS\Records\RecordCollection */ - public function getAnswerRecords() + public function getAnswerRecords(): RecordCollection { return $this->answerRecords; } @@ -301,7 +298,7 @@ public function getAnswerRecords() * * @return \LibDNS\Records\RecordCollection */ - public function getAuthorityRecords() + public function getAuthorityRecords(): RecordCollection { return $this->authorityRecords; } @@ -311,7 +308,7 @@ public function getAuthorityRecords() * * @return \LibDNS\Records\RecordCollection */ - public function getAdditionalRecords() + public function getAdditionalRecords(): RecordCollection { return $this->additionalRecords; } diff --git a/src/Messages/MessageFactory.php b/src/Messages/MessageFactory.php index d83b7a5..fd6e694 100644 --- a/src/Messages/MessageFactory.php +++ b/src/Messages/MessageFactory.php @@ -30,7 +30,7 @@ class MessageFactory * @param int $type Value of the message type field * @return \LibDNS\Messages\Message */ - public function create($type = null) + public function create(int $type = null): Message { return new Message(new RecordCollectionFactory, $type); } diff --git a/src/Messages/MessageOpCodes.php b/src/Messages/MessageOpCodes.php index 5a4d049..dc43096 100644 --- a/src/Messages/MessageOpCodes.php +++ b/src/Messages/MessageOpCodes.php @@ -22,7 +22,7 @@ * @package Messages * @author Chris Wright */ -class MessageOpCodes extends Enumeration +final class MessageOpCodes extends Enumeration { const QUERY = 0; const IQUERY = 1; diff --git a/src/Messages/MessageResponseCodes.php b/src/Messages/MessageResponseCodes.php index c1631a6..0faf1dc 100644 --- a/src/Messages/MessageResponseCodes.php +++ b/src/Messages/MessageResponseCodes.php @@ -22,7 +22,7 @@ * @package Messages * @author Chris Wright */ -class MessageResponseCodes extends Enumeration +final class MessageResponseCodes extends Enumeration { const NO_ERROR = 0; const FORMAT_ERROR = 1; diff --git a/src/Messages/MessageTypes.php b/src/Messages/MessageTypes.php index dbb2840..437a1fd 100644 --- a/src/Messages/MessageTypes.php +++ b/src/Messages/MessageTypes.php @@ -22,7 +22,7 @@ * @package Messages * @author Chris Wright */ -class MessageTypes extends Enumeration +final class MessageTypes extends Enumeration { const QUERY = 0; const RESPONSE = 1; diff --git a/src/Packets/LabelRegistry.php b/src/Packets/LabelRegistry.php index 1af7969..3d11852 100644 --- a/src/Packets/LabelRegistry.php +++ b/src/Packets/LabelRegistry.php @@ -39,13 +39,13 @@ class LabelRegistry * @param string|string[] $labels * @param int $index */ - public function register($labels, $index) + public function register($labels, int $index) { - if (is_array($labels)) { + if (\is_array($labels)) { $labelsArr = $labels; - $labelsStr = implode('.', $labels); + $labelsStr = \implode('.', $labels); } else { - $labelsArr = explode('.', $labels); + $labelsArr = \explode('.', $labels); $labelsStr = (string) $labels; } @@ -62,9 +62,9 @@ public function register($labels, $index) * @param string $label * @return int|null */ - public function lookupIndex($label) + public function lookupIndex(string $label) { - return isset($this->labels[$label]) ? $this->labels[$label] : null; + return $this->labels[$label] ?? null; } /** @@ -73,8 +73,8 @@ public function lookupIndex($label) * @param int $index * @return string[]|null */ - public function lookupLabel($index) + public function lookupLabel(int $index) { - return isset($this->indexes[$index]) ? $this->indexes[$index] : null; + return $this->indexes[$index] ?? null; } } diff --git a/src/Packets/Packet.php b/src/Packets/Packet.php index 2a4e79d..19b64b1 100644 --- a/src/Packets/Packet.php +++ b/src/Packets/Packet.php @@ -42,10 +42,10 @@ class Packet * * @param string $data The initial packet raw data */ - public function __construct($data = '') + public function __construct(string $data = '') { - $this->data = (string) $data; - $this->length = strlen($this->data); + $this->data = $data; + $this->length = \strlen($this->data); } /** @@ -55,22 +55,21 @@ public function __construct($data = '') * @return string * @throws \OutOfBoundsException When the pointer position is invalid or the supplied length is negative */ - public function read($length = null) + public function read(int $length = null): string { if ($this->pointer > $this->length) { throw new \OutOfBoundsException('Pointer position invalid'); } if ($length === null) { - $result = substr($this->data, $this->pointer); + $result = \substr($this->data, $this->pointer); $this->pointer = $this->length; } else { - $length = (int) $length; if ($length < 0) { throw new \OutOfBoundsException('Length must be a positive integer'); } - $result = substr($this->data, $this->pointer, (int) $length); + $result = \substr($this->data, $this->pointer, $length); $this->pointer += $length; } @@ -83,9 +82,9 @@ public function read($length = null) * @param string $data The data to append * @return int The number of bytes written */ - public function write($data) + public function write(string $data): int { - $length = strlen($data); + $length = \strlen($data); $this->data .= $data; $this->length += $length; @@ -106,7 +105,7 @@ public function reset() * * @return int */ - public function getPointer() + public function getPointer(): int { return $this->pointer; } @@ -116,7 +115,7 @@ public function getPointer() * * @return int */ - public function getLength() + public function getLength(): int { return $this->length; } @@ -126,7 +125,7 @@ public function getLength() * * @return int */ - public function getBytesRemaining() + public function getBytesRemaining(): int { return $this->length - $this->pointer; } diff --git a/src/Packets/PacketFactory.php b/src/Packets/PacketFactory.php index 9968afa..5ffad14 100644 --- a/src/Packets/PacketFactory.php +++ b/src/Packets/PacketFactory.php @@ -28,7 +28,7 @@ class PacketFactory * @param string $data * @return \LibDNS\Packets\Packet */ - public function create($data = '') + public function create(string $data = ''): Packet { return new Packet($data); } diff --git a/src/Records/Question.php b/src/Records/Question.php index 34f521c..24bb05b 100644 --- a/src/Records/Question.php +++ b/src/Records/Question.php @@ -30,7 +30,7 @@ class Question extends Record * @param \LibDNS\Records\Types\TypeFactory $typeFactory * @param int $type Resource type being requested, can be indicated using the ResourceQTypes enum */ - public function __construct(TypeFactory $typeFactory, $type) + public function __construct(TypeFactory $typeFactory, int $type) { $this->typeFactory = $typeFactory; $this->type = $type; diff --git a/src/Records/QuestionFactory.php b/src/Records/QuestionFactory.php index 86e9273..a0e0cb9 100644 --- a/src/Records/QuestionFactory.php +++ b/src/Records/QuestionFactory.php @@ -30,7 +30,7 @@ class QuestionFactory * @param int $type The resource type * @return \LibDNS\Records\Question */ - public function create($type) + public function create(int $type): Question { return new Question(new TypeFactory, $type); } diff --git a/src/Records/RData.php b/src/Records/RData.php index 2548f93..f184d08 100644 --- a/src/Records/RData.php +++ b/src/Records/RData.php @@ -58,9 +58,9 @@ public function __construct(TypeDefinition $typeDef) public function __toString() { if ($handler = $this->typeDef->getToStringFunction()) { - $result = call_user_func_array($handler, $this->fields); + $result = \call_user_func_array($handler, $this->fields); } else { - $result = implode(',', $this->fields); + $result = \implode(',', $this->fields); } return $result; @@ -73,7 +73,7 @@ public function __toString() * @return \LibDNS\Records\Types\Type * @throws \OutOfBoundsException When the supplied index does not refer to a valid field */ - public function getField($index) + public function getField(int $index) { if (!isset($this->fields[$index])) { throw new \OutOfBoundsException('Index ' . $index . ' does not refer to a valid field'); @@ -89,7 +89,7 @@ public function getField($index) * @param \LibDNS\Records\Types\Type $value * @throws \InvalidArgumentException When the supplied index/value pair does not match the type definition */ - public function setField($index, Type $value) + public function setField(int $index, Type $value) { if (!$this->typeDef->getFieldDefinition($index)->assertDataValid($value)) { throw new \InvalidArgumentException('The supplied value is not valid for the specified index'); @@ -105,7 +105,7 @@ public function setField($index, Type $value) * @return \LibDNS\Records\Types\Type * @throws \OutOfBoundsException When the supplied name does not refer to a valid field */ - public function getFieldByName($name) + public function getFieldByName(string $name): Type { return $this->getField($this->typeDef->getFieldIndexByName($name)); } @@ -118,7 +118,7 @@ public function getFieldByName($name) * @throws \OutOfBoundsException When the supplied name does not refer to a valid field * @throws \InvalidArgumentException When the supplied value does not match the type definition */ - public function setFieldByName($name, Type $value) + public function setFieldByName(string $name, Type $value) { $this->setField($this->typeDef->getFieldIndexByName($name), $value); } @@ -128,7 +128,7 @@ public function setFieldByName($name, Type $value) * * @return \LibDNS\Records\TypeDefinitions\TypeDefinition */ - public function getTypeDefinition() + public function getTypeDefinition(): TypeDefinition { return $this->typeDef; } @@ -138,9 +138,9 @@ public function getTypeDefinition() * * @return \LibDNS\Records\Types\Type */ - public function current() + public function current(): Type { - return current($this->fields); + return \current($this->fields); } /** @@ -148,9 +148,9 @@ public function current() * * @return int */ - public function key() + public function key(): int { - return key($this->fields); + return \key($this->fields); } /** @@ -158,7 +158,7 @@ public function key() */ public function next() { - $this->pointerValid = next($this->fields) !== false; + $this->pointerValid = \next($this->fields) !== false; } /** @@ -166,8 +166,8 @@ public function next() */ public function rewind() { - reset($this->fields); - $this->pointerValid = count($this->fields) > 0; + \reset($this->fields); + $this->pointerValid = \count($this->fields) > 0; } /** @@ -175,7 +175,7 @@ public function rewind() * * @return bool */ - public function valid() + public function valid(): bool { return $this->pointerValid; } @@ -185,8 +185,8 @@ public function valid() * * @return int */ - public function count() + public function count(): int { - return count($this->fields); + return \count($this->fields); } } diff --git a/src/Records/RDataBuilder.php b/src/Records/RDataBuilder.php index af57436..b8734b5 100644 --- a/src/Records/RDataBuilder.php +++ b/src/Records/RDataBuilder.php @@ -53,7 +53,7 @@ public function __construct(RDataFactory $rDataFactory, TypeBuilder $typeBuilder * @param \LibDNS\Records\TypeDefinitions\TypeDefinition $typeDefinition * @return \LibDNS\Records\RData */ - public function build(TypeDefinition $typeDefinition) + public function build(TypeDefinition $typeDefinition): RData { $rData = $this->rDataFactory->create($typeDefinition); diff --git a/src/Records/RDataFactory.php b/src/Records/RDataFactory.php index e144d2d..7b60cda 100644 --- a/src/Records/RDataFactory.php +++ b/src/Records/RDataFactory.php @@ -30,7 +30,7 @@ class RDataFactory * @param \LibDNS\Records\TypeDefinitions\TypeDefinition $typeDefinition * @return \LibDNS\Records\RData */ - public function create(TypeDefinition $typeDefinition) + public function create(TypeDefinition $typeDefinition): RData { return new RData($typeDefinition); } diff --git a/src/Records/Record.php b/src/Records/Record.php index e6fb202..cf0b909 100644 --- a/src/Records/Record.php +++ b/src/Records/Record.php @@ -49,7 +49,7 @@ abstract class Record * * @return \LibDNS\Records\Types\DomainName */ - public function getName() + public function getName(): DomainName { return $this->name; } @@ -63,7 +63,7 @@ public function getName() public function setName($name) { if (!($name instanceof DomainName)) { - $name = $this->typeFactory->createDomainName($name); + $name = $this->typeFactory->createDomainName((string)$name); } $this->name = $name; @@ -74,7 +74,7 @@ public function setName($name) * * @return int */ - public function getType() + public function getType(): int { return $this->type; } @@ -84,7 +84,7 @@ public function getType() * * @return int */ - public function getClass() + public function getClass(): int { return $this->class; } @@ -95,9 +95,8 @@ public function getClass() * @param int $class The new value, can be indicated using the ResourceClasses/ResourceQClasses enums * @throws \RangeException When the supplied value is outside the valid range 0 - 65535 */ - public function setClass($class) + public function setClass(int $class) { - $class = (int) $class; if ($class < 0 || $class > 65535) { throw new \RangeException('Record class must be in the range 0 - 65535'); } diff --git a/src/Records/RecordCollection.php b/src/Records/RecordCollection.php index 4aea737..d7224c1 100644 --- a/src/Records/RecordCollection.php +++ b/src/Records/RecordCollection.php @@ -86,7 +86,7 @@ private function removeFromNameMap(Record $record) if (!empty($this->nameMap[$name = (string) $record->getName()])) { foreach ($this->nameMap[$name] as $key => $item) { if ($item === $record) { - array_splice($this->nameMap[$name], $key, 1); + \array_splice($this->nameMap[$name], $key, 1); break; } } @@ -141,9 +141,9 @@ public function remove(Record $record) * @param bool $sameInstance Whether to perform strict comparisons in search * @return bool */ - public function contains(Record $record, $sameInstance = false) + public function contains(Record $record, bool $sameInstance = false): bool { - return in_array($record, $this->records, (bool) $sameInstance); + return \in_array($record, $this->records, $sameInstance); } /** @@ -152,9 +152,9 @@ public function contains(Record $record, $sameInstance = false) * @param string $name The name to match records against * @return \LibDNS\Records\Record[] */ - public function getRecordsByName($name) + public function getRecordsByName(string $name): array { - return isset($this->nameMap[$name = strtolower($name)]) ? $this->nameMap[$name] : []; + return $this->nameMap[\strtolower($name)] ?? []; } /** @@ -164,7 +164,7 @@ public function getRecordsByName($name) * @return \LibDNS\Records\Record * @throws \OutOfBoundsException When the supplied index does not refer to a valid record */ - public function getRecordByIndex($index) + public function getRecordByIndex(int $index): Record { if (isset($this->records[$index])) { return $this->records[$index]; @@ -179,11 +179,11 @@ public function getRecordByIndex($index) * @param string $name The name to match records against * @return int The number of records removed */ - public function clearRecordsByName($name) + public function clearRecordsByName(string $name): int { $count = 0; - if (isset($this->nameMap[$name = strtolower($name)])) { + if (isset($this->nameMap[$name = \strtolower($name)])) { unset($this->nameMap[$name]); foreach ($this->records as $index => $record) { @@ -193,7 +193,7 @@ public function clearRecordsByName($name) } } - $this->records = array_values($this->records); + $this->records = \array_values($this->records); } return $count; @@ -213,9 +213,9 @@ public function clear() * * @return string[] */ - public function getNames() + public function getNames(): array { - return array_keys($this->nameMap); + return \array_keys($this->nameMap); } /** @@ -223,7 +223,7 @@ public function getNames() * * @return int */ - public function getType() + public function getType(): int { return $this->type; } @@ -234,7 +234,7 @@ public function getType() * @return \LibDNS\Records\Record * @throws \OutOfBoundsException When the pointer does not refer to a valid record */ - public function current() + public function current(): Record { if (!isset($this->records[$this->position])) { throw new \OutOfBoundsException('The current pointer position is invalid'); @@ -248,7 +248,7 @@ public function current() * * @return int */ - public function key() + public function key(): int { return $this->position; } @@ -274,7 +274,7 @@ public function rewind() * * @return bool */ - public function valid() + public function valid(): bool { return isset($this->records[$this->position]); } @@ -284,7 +284,7 @@ public function valid() * * @return int */ - public function count() + public function count(): int { return $this->length; } diff --git a/src/Records/RecordCollectionFactory.php b/src/Records/RecordCollectionFactory.php index 9db6b42..95428fe 100644 --- a/src/Records/RecordCollectionFactory.php +++ b/src/Records/RecordCollectionFactory.php @@ -29,7 +29,7 @@ class RecordCollectionFactory * @return \LibDNS\Records\RecordCollection * @throws \InvalidArgumentException When the specified record type is invalid */ - public function create($type) + public function create(int $type): RecordCollection { return new RecordCollection($type); } diff --git a/src/Records/RecordTypes.php b/src/Records/RecordTypes.php index b2c43a2..f81a1e4 100644 --- a/src/Records/RecordTypes.php +++ b/src/Records/RecordTypes.php @@ -22,7 +22,7 @@ * @package Records * @author Chris Wright */ -class RecordTypes extends Enumeration +final class RecordTypes extends Enumeration { const QUESTION = 0; const RESOURCE = 1; diff --git a/src/Records/Resource.php b/src/Records/Resource.php index 0435cad..471d385 100644 --- a/src/Records/Resource.php +++ b/src/Records/Resource.php @@ -41,7 +41,7 @@ class Resource extends Record * @param int $type Can be indicated using the ResourceTypes enum * @param \LibDNS\Records\RData $data */ - public function __construct(TypeFactory $typeFactory, $type, $data) + public function __construct(TypeFactory $typeFactory, int $type, RData $data) { $this->typeFactory = $typeFactory; $this->type = $type; @@ -53,7 +53,7 @@ public function __construct(TypeFactory $typeFactory, $type, $data) * * @return int */ - public function getTTL() + public function getTTL(): int { return $this->ttl; } @@ -64,9 +64,8 @@ public function getTTL() * @param int $ttl The new value * @throws \RangeException When the supplied value is outside the valid range 0 - 4294967296 */ - public function setTTL($ttl) + public function setTTL(int $ttl) { - $ttl = (int) $ttl; if ($ttl < 0 || $ttl > 4294967296) { throw new \RangeException('Record class must be in the range 0 - 4294967296'); } @@ -79,7 +78,7 @@ public function setTTL($ttl) * * @return \LibDNS\Records\RData */ - public function getData() + public function getData(): RData { return $this->data; } diff --git a/src/Records/ResourceBuilder.php b/src/Records/ResourceBuilder.php index e845e92..93e021e 100644 --- a/src/Records/ResourceBuilder.php +++ b/src/Records/ResourceBuilder.php @@ -59,7 +59,7 @@ public function __construct(ResourceFactory $resourceFactory, RDataBuilder $rDat * @param int $type Type of the resource, can be indicated using the ResourceTypes enum * @return \LibDNS\Records\Resource */ - public function build($type) + public function build(int $type): Resource { $typeDefinition = $this->typeDefinitionManager->getTypeDefinition($type); $rData = $this->rDataBuilder->build($typeDefinition); diff --git a/src/Records/ResourceBuilderFactory.php b/src/Records/ResourceBuilderFactory.php index f224252..1bac743 100644 --- a/src/Records/ResourceBuilderFactory.php +++ b/src/Records/ResourceBuilderFactory.php @@ -34,7 +34,7 @@ class ResourceBuilderFactory * @param \LibDNS\Records\TypeDefinitions\TypeDefinitionManager $typeDefinitionManager * @return \LibDNS\Records\ResourceBuilder */ - public function create(TypeDefinitionManager $typeDefinitionManager = null) + public function create(TypeDefinitionManager $typeDefinitionManager = null): ResourceBuilder { return new ResourceBuilder( new ResourceFactory, diff --git a/src/Records/ResourceClasses.php b/src/Records/ResourceClasses.php index 394e838..53853dd 100644 --- a/src/Records/ResourceClasses.php +++ b/src/Records/ResourceClasses.php @@ -22,7 +22,7 @@ * @package Records * @author Chris Wright */ -class ResourceClasses extends Enumeration +abstract class ResourceClasses extends Enumeration { const IN = 1; const CS = 2; diff --git a/src/Records/ResourceFactory.php b/src/Records/ResourceFactory.php index e8eb7c8..627a7f7 100644 --- a/src/Records/ResourceFactory.php +++ b/src/Records/ResourceFactory.php @@ -31,7 +31,7 @@ class ResourceFactory * @param \LibDNS\Records\RData $data * @return \LibDNS\Records\Resource */ - public function create($type, $data) + public function create(int $type, RData $data): Resource { return new Resource(new TypeFactory, $type, $data); } diff --git a/src/Records/ResourceQClasses.php b/src/Records/ResourceQClasses.php index 3f52632..e75a102 100644 --- a/src/Records/ResourceQClasses.php +++ b/src/Records/ResourceQClasses.php @@ -20,7 +20,7 @@ * @package Records * @author Chris Wright */ -class ResourceQClasses extends ResourceClasses +final class ResourceQClasses extends ResourceClasses { const ANY = 255; } diff --git a/src/Records/ResourceQTypes.php b/src/Records/ResourceQTypes.php index 2e2ab90..dc00042 100644 --- a/src/Records/ResourceQTypes.php +++ b/src/Records/ResourceQTypes.php @@ -20,7 +20,7 @@ * @package Records * @author Chris Wright */ -class ResourceQTypes extends ResourceTypes +final class ResourceQTypes extends ResourceTypes { const AXFR = 252; const MAILB = 253; diff --git a/src/Records/ResourceTypes.php b/src/Records/ResourceTypes.php index a717914..60f9717 100644 --- a/src/Records/ResourceTypes.php +++ b/src/Records/ResourceTypes.php @@ -22,7 +22,7 @@ * @package Records * @author Chris Wright */ -class ResourceTypes extends Enumeration +abstract class ResourceTypes extends Enumeration { const A = 1; const AAAA = 28; diff --git a/src/Records/TypeDefinitions/FieldDefinition.php b/src/Records/TypeDefinitions/FieldDefinition.php index 980c197..df304a5 100644 --- a/src/Records/TypeDefinitions/FieldDefinition.php +++ b/src/Records/TypeDefinitions/FieldDefinition.php @@ -68,13 +68,13 @@ class FieldDefinition * @param bool $allowsMultiple * @param int $minimumValues */ - public function __construct($index, $name, $type, $allowsMultiple, $minimumValues) + public function __construct(int $index, string $name, int $type, bool $allowsMultiple, int $minimumValues) { - $this->index = (int) $index; - $this->name = (string) $name; - $this->type = (int) $type; - $this->allowsMultiple = (bool) $allowsMultiple; - $this->minimumValues = (int) $minimumValues; + $this->index = $index; + $this->name = $name; + $this->type = $type; + $this->allowsMultiple = $allowsMultiple; + $this->minimumValues = $minimumValues; } /** @@ -82,7 +82,7 @@ public function __construct($index, $name, $type, $allowsMultiple, $minimumValue * * @return int */ - public function getIndex() + public function getIndex(): int { return $this->index; } @@ -92,7 +92,7 @@ public function getIndex() * * @return string */ - public function getName() + public function getName(): string { return $this->name; } @@ -102,7 +102,7 @@ public function getName() * * @return int */ - public function getType() + public function getType(): int { return $this->type; } @@ -112,7 +112,7 @@ public function getType() * * @return bool */ - public function allowsMultiple() + public function allowsMultiple(): bool { return $this->allowsMultiple; } @@ -122,7 +122,7 @@ public function allowsMultiple() * * @return int */ - public function getMinimumValues() + public function getMinimumValues(): int { return $this->minimumValues; } @@ -133,7 +133,7 @@ public function getMinimumValues() * @param \LibDNS\Records\Types\Type * @return bool */ - public function assertDataValid(Type $value) + public function assertDataValid(Type $value): bool { return (($this->type & Types::ANYTHING) && $value instanceof Anything) || (($this->type & Types::BITMAP) && $value instanceof BitMap) diff --git a/src/Records/TypeDefinitions/FieldDefinitionFactory.php b/src/Records/TypeDefinitions/FieldDefinitionFactory.php index 065ecdb..afd2b1e 100644 --- a/src/Records/TypeDefinitions/FieldDefinitionFactory.php +++ b/src/Records/TypeDefinitions/FieldDefinitionFactory.php @@ -32,7 +32,7 @@ class FieldDefinitionFactory * @param int $minimumValues * @return \LibDNS\Records\TypeDefinitions\FieldDefinition */ - public function create($index, $name, $type, $allowsMultiple, $minimumValues) + public function create(int $index, string $name, int $type, bool $allowsMultiple, int $minimumValues): FieldDefinition { return new FieldDefinition($index, $name, $type, $allowsMultiple, $minimumValues); } diff --git a/src/Records/TypeDefinitions/TypeDefinition.php b/src/Records/TypeDefinitions/TypeDefinition.php index 40dbe3d..151b580 100644 --- a/src/Records/TypeDefinitions/TypeDefinition.php +++ b/src/Records/TypeDefinitions/TypeDefinition.php @@ -69,7 +69,7 @@ public function __construct(FieldDefinitionFactory $fieldDefFactory, array $defi $this->fieldDefFactory = $fieldDefFactory; if (isset($definition['__toString'])) { - if (!is_callable($definition['__toString'])) { + if (!\is_callable($definition['__toString'])) { throw new \InvalidArgumentException('Invalid type definition: __toString() implementation is not callable'); } @@ -77,7 +77,7 @@ public function __construct(FieldDefinitionFactory $fieldDefFactory, array $defi unset($definition['__toString']); } - $this->fieldCount = count($definition); + $this->fieldCount = \count($definition); $index = 0; foreach ($definition as $name => $type) { $this->registerField($index++, $name, $type); @@ -92,9 +92,9 @@ public function __construct(FieldDefinitionFactory $fieldDefFactory, array $defi * @param int $type * @throws \InvalidArgumentException When the field definition is invalid */ - private function registerField($index, $name, $type) + private function registerField(int $index, string $name, int $type) { - if (!preg_match('/^(?P[\w\-]+)(?P\+|\*)?(?P(?<=\+)\d+)?$/', strtolower($name), $matches)) { + if (!\preg_match('/^(?P[\w\-]+)(?P\+|\*)?(?P(?<=\+)\d+)?$/', \strtolower($name), $matches)) { throw new \InvalidArgumentException('Invalid field definition ' . $name . ': Syntax error'); } @@ -129,9 +129,8 @@ private function registerField($index, $name, $type) * @return \LibDNS\Records\TypeDefinitions\FieldDefinition * @throws \OutOfBoundsException When the supplied index does not refer to a valid field */ - public function getFieldDefinition($index) + public function getFieldDefinition(int $index): FieldDefinition { - $index = (int) $index; if (isset($this->fieldDefs[$index])) { $fieldDef = $this->fieldDefs[$index]; } else if ($index >= 0 && $this->lastField->allowsMultiple()) { @@ -150,9 +149,9 @@ public function getFieldDefinition($index) * @return int * @throws \OutOfBoundsException When the supplied name does not refer to a valid field */ - public function getFieldIndexByName($name) + public function getFieldIndexByName($name): int { - $fieldName = strtolower($name); + $fieldName = \strtolower($name); if (!isset($this->fieldNameMap[$fieldName])) { throw new \OutOfBoundsException('Name ' . $name . ' does not refer to a valid field'); } @@ -185,7 +184,7 @@ public function setToStringFunction(callable $function) * * @return \LibDNS\Records\TypeDefinitions\FieldDefinition */ - public function current() + public function current(): FieldDefinition { return current($this->fieldDefs); } @@ -195,7 +194,7 @@ public function current() * * @return int */ - public function key() + public function key(): int { return key($this->fieldDefs); } @@ -205,7 +204,7 @@ public function key() */ public function next() { - $this->pointerValid = next($this->fieldDefs) !== false; + $this->pointerValid = \next($this->fieldDefs) !== false; } /** @@ -213,8 +212,8 @@ public function next() */ public function rewind() { - reset($this->fieldDefs); - $this->pointerValid = count($this->fieldDefs) > 0; + \reset($this->fieldDefs); + $this->pointerValid = \count($this->fieldDefs) > 0; } /** @@ -222,7 +221,7 @@ public function rewind() * * @return bool */ - public function valid() + public function valid(): bool { return $this->pointerValid; } @@ -232,7 +231,7 @@ public function valid() * * @return int */ - public function count() + public function count(): int { return $this->fieldCount; } diff --git a/src/Records/TypeDefinitions/TypeDefinitionFactory.php b/src/Records/TypeDefinitions/TypeDefinitionFactory.php index 2fe5f46..18cc00c 100644 --- a/src/Records/TypeDefinitions/TypeDefinitionFactory.php +++ b/src/Records/TypeDefinitions/TypeDefinitionFactory.php @@ -30,7 +30,7 @@ class TypeDefinitionFactory * @return \LibDNS\Records\TypeDefinitions\TypeDefinition * @throws \InvalidArgumentException When the type definition is invalid */ - public function create(FieldDefinitionFactory $fieldDefinitionFactory, array $definition) + public function create(FieldDefinitionFactory $fieldDefinitionFactory, array $definition): TypeDefinition { return new TypeDefinition($fieldDefinitionFactory, $definition); } diff --git a/src/Records/TypeDefinitions/TypeDefinitionManager.php b/src/Records/TypeDefinitions/TypeDefinitionManager.php index 827951b..be4da0a 100644 --- a/src/Records/TypeDefinitions/TypeDefinitionManager.php +++ b/src/Records/TypeDefinitions/TypeDefinitionManager.php @@ -244,10 +244,8 @@ private function setDefinitions() * @param int $recordType Resource type, can be indicated using the ResourceTypes enum * @return \LibDNS\Records\TypeDefinitions\TypeDefinition */ - public function getTypeDefinition($recordType) + public function getTypeDefinition(int $recordType) { - $recordType = (int) $recordType; - if (!isset($this->typeDefs[$recordType])) { $definition = isset($this->definitions[$recordType]) ? $this->definitions[$recordType] : ['data' => Types::ANYTHING]; $this->typeDefs[$recordType] = $this->typeDefFactory->create($this->fieldDefFactory, $definition); @@ -263,16 +261,16 @@ public function getTypeDefinition($recordType) * @param int[]|\LibDNS\Records\TypeDefinitions\TypeDefinition $definition * @throws \InvalidArgumentException When the type definition is invalid */ - public function registerTypeDefinition($recordType, $definition) + public function registerTypeDefinition(int $recordType, $definition) { if (!($definition instanceof TypeDefinition)) { - if (!is_array($definition)) { + if (!\is_array($definition)) { throw new \InvalidArgumentException('Definition must be an array or an instance of ' . __NAMESPACE__ . '\TypeDefinition'); } - $definition = (int) $this->typeDefFactory->create($this->fieldDefFactory, $definition); + $definition = $this->typeDefFactory->create($this->fieldDefFactory, $definition); } - $this->typeDefs[(int) $recordType] = $definition; + $this->typeDefs[$recordType] = $definition; } } diff --git a/src/Records/TypeDefinitions/TypeDefinitionManagerFactory.php b/src/Records/TypeDefinitions/TypeDefinitionManagerFactory.php index 44e3a5e..4107de7 100644 --- a/src/Records/TypeDefinitions/TypeDefinitionManagerFactory.php +++ b/src/Records/TypeDefinitions/TypeDefinitionManagerFactory.php @@ -27,7 +27,7 @@ class TypeDefinitionManagerFactory * * @return \LibDNS\Records\TypeDefinitions\TypeDefinitionManager */ - public function create() + public function create(): TypeDefinitionManager { return new TypeDefinitionManager(new TypeDefinitionFactory, new FieldDefinitionFactory); } diff --git a/src/Records/Types/Anything.php b/src/Records/Types/Anything.php index c2d3ef0..e334764 100644 --- a/src/Records/Types/Anything.php +++ b/src/Records/Types/Anything.php @@ -33,10 +33,9 @@ class Anything extends Type * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is outside the valid length range 0 - 65535 */ - public function setValue($value) + public function setValue(string $value) { - $value = (string) $value; - if (strlen($value) > 65535) { + if (\strlen($value) > 65535) { throw new \UnexpectedValueException('Untyped string length must be in the range 0 - 65535'); } diff --git a/src/Records/Types/BitMap.php b/src/Records/Types/BitMap.php index b22a849..ced2cf2 100644 --- a/src/Records/Types/BitMap.php +++ b/src/Records/Types/BitMap.php @@ -32,9 +32,9 @@ class BitMap extends Type * * @param string $value The new value */ - public function setValue($value) + public function setValue(string $value) { - $this->value = (string) $value; + $this->value = $value; } /** @@ -44,22 +44,22 @@ public function setValue($value) * @param bool $newValue The new value * @return bool The old value */ - public function isBitSet($index, $newValue = null) + public function isBitSet(int $index, bool $newValue = null): bool { $charIndex = (int)($index / 8); $bitMask = 0b10000000 >> ($index % 8); $result = false; if (isset($this->value[$charIndex])) { - $result = (bool) (ord($this->value[$charIndex]) & $bitMask); + $result = (bool) (\ord($this->value[$charIndex]) & $bitMask); } if (isset($newValue) && $newValue != $result) { if (!isset($this->value[$charIndex])) { - $this->value = str_pad($this->value, $charIndex + 1, "\x00", STR_PAD_RIGHT); + $this->value = \str_pad($this->value, $charIndex + 1, "\x00", STR_PAD_RIGHT); } - $this->value[$charIndex] = chr((ord($this->value[$charIndex]) & ~$bitMask) | ($newValue ? $bitMask : 0)); + $this->value[$charIndex] = \chr((\ord($this->value[$charIndex]) & ~$bitMask) | ($newValue ? $bitMask : 0)); } return $result; diff --git a/src/Records/Types/Char.php b/src/Records/Types/Char.php index e297273..bbc4e8e 100644 --- a/src/Records/Types/Char.php +++ b/src/Records/Types/Char.php @@ -30,13 +30,14 @@ class Char extends Type /** * Set the internal value * - * @param int $value The new value + * @param string $value The new value * @throws \UnderflowException When the supplied value is less than 0 * @throws \OverflowException When the supplied value is greater than 255 */ - public function setValue($value) + public function setValue(string $value) { $value = (int) $value; + if ($value < 0) { throw new \UnderflowException('Char value must be in the range 0 - 255'); } else if ($value > 255) { diff --git a/src/Records/Types/CharacterString.php b/src/Records/Types/CharacterString.php index 5f07da5..f40ecf2 100644 --- a/src/Records/Types/CharacterString.php +++ b/src/Records/Types/CharacterString.php @@ -33,10 +33,9 @@ class CharacterString extends Type * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is outside the valid length range 0 - 255 */ - public function setValue($value) + public function setValue(string $value) { - $value = (string) $value; - if (strlen($value) > 255) { + if (\strlen($value) > 255) { throw new \UnexpectedValueException('Character string length must be in the range 0 - 255'); } diff --git a/src/Records/Types/DomainName.php b/src/Records/Types/DomainName.php index 5dc458c..3011a44 100644 --- a/src/Records/Types/DomainName.php +++ b/src/Records/Types/DomainName.php @@ -42,7 +42,7 @@ class DomainName extends Type */ public function __construct($value = null) { - if (is_array($value)) { + if (\is_array($value)) { $this->setLabels($value); } else { parent::__construct($value); @@ -55,9 +55,9 @@ public function __construct($value = null) * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is not a valid domain name */ - public function setValue($value) + public function setValue(string $value) { - $this->setLabels(explode('.', $value)); + $this->setLabels(\explode('.', $value)); } /** @@ -66,9 +66,9 @@ public function setValue($value) * @param bool $tldFirst Whether to return the label list ordered with the TLD label first * @return string[] */ - public function getLabels($tldFirst = false) + public function getLabels($tldFirst = false): array { - return $tldFirst ? array_reverse($this->labels) : $this->labels; + return $tldFirst ? \array_reverse($this->labels) : $this->labels; } /** @@ -92,7 +92,7 @@ public function setLabels(array $labels, $tldFirst = false) throw new \InvalidArgumentException('Label list is not a valid domain name: Label ' . $label . ' length exceeds 63 byte limit'); } $length += $labelLength + 1; - $label = strtolower($label); + $label = \strtolower($label); $count++; } @@ -105,7 +105,7 @@ public function setLabels(array $labels, $tldFirst = false) throw new \InvalidArgumentException('Label list is not a valid domain name: Total length exceeds 255 byte limit'); } - $this->labels = $tldFirst ? array_reverse($labels) : $labels; - $this->value = implode('.', $this->labels); + $this->labels = $tldFirst ? \array_reverse($labels) : $labels; + $this->value = \implode('.', $this->labels); } } diff --git a/src/Records/Types/IPv4Address.php b/src/Records/Types/IPv4Address.php index fad4853..7362e43 100644 --- a/src/Records/Types/IPv4Address.php +++ b/src/Records/Types/IPv4Address.php @@ -40,7 +40,7 @@ class IPv4Address extends Type */ public function __construct($value = null) { - if (is_array($value)) { + if (\is_array($value)) { $this->setOctets($value); } else { parent::__construct($value); @@ -53,9 +53,9 @@ public function __construct($value = null) * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is outside the valid length range 0 - 65535 */ - public function setValue($value) + public function setValue(string $value) { - $this->setOctets(explode('.', $value)); + $this->setOctets(\explode('.', $value)); } /** @@ -63,7 +63,7 @@ public function setValue($value) * * @return int[] */ - public function getOctets() + public function getOctets(): array { return $this->octets; } @@ -76,19 +76,19 @@ public function getOctets() */ public function setOctets(array $octets) { - if (count($octets) !== 4) { + if (\count($octets) !== 4) { throw new \UnexpectedValueException('Octet list is not a valid IPv4 address: invalid octet count'); } foreach ($octets as &$octet) { - if (strspn((string)$octet, "0123456789") !== strlen($octet) || $octet < 0x00 || $octet > 0xff) { + if (\strspn((string)$octet, "0123456789") !== \strlen($octet) || $octet < 0x00 || $octet > 0xff) { throw new \UnexpectedValueException('Octet list is not a valid IPv4 address: invalid octet value ' . $octet); } $octet = (int) $octet; } - $this->octets = array_values($octets); - $this->value = implode('.', $this->octets); + $this->octets = \array_values($octets); + $this->value = \implode('.', $this->octets); } } diff --git a/src/Records/Types/IPv6Address.php b/src/Records/Types/IPv6Address.php index ac0f96f..b4979a0 100644 --- a/src/Records/Types/IPv6Address.php +++ b/src/Records/Types/IPv6Address.php @@ -61,7 +61,7 @@ private function createCompressedString($shorts) $currentPos = $currentLen = 0; } - $shorts[$i] = dechex($shorts[$i]); + $shorts[$i] = \dechex($shorts[$i]); } if ($inBlock) { $compressLen = $currentLen; @@ -77,10 +77,10 @@ private function createCompressedString($shorts) $replace = ['']; } - array_splice($shorts, $compressPos, $compressLen, $replace); + \array_splice($shorts, $compressPos, $compressLen, $replace); } - return implode(':', $shorts); + return \implode(':', $shorts); } /** @@ -91,7 +91,7 @@ private function createCompressedString($shorts) */ public function __construct($value = null) { - if (is_array($value)) { + if (\is_array($value)) { $this->setShorts($value); } else { parent::__construct($value); @@ -104,22 +104,22 @@ public function __construct($value = null) * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is outside the valid length range 0 - 65535 */ - public function setValue($value) + public function setValue(string $value) { - $shorts = explode(':', (string) $value); + $shorts = \explode(':', $value); - $count = count($shorts); + $count = \count($shorts); if ($count < 3 || $count > 8) { throw new \UnexpectedValueException('Value is not a valid IPv6 address: invalid short count'); } else if ($shorts[0] === '' && $shorts[1] === '') { - $shorts = array_pad($shorts, -8, '0'); + $shorts = \array_pad($shorts, -8, '0'); } else if ($shorts[$count - 2] === '' && $shorts[$count - 1] === '') { - $shorts = array_pad($shorts, 8, '0'); - } else if (false !== $pos = array_search('', $shorts, true)) { - array_splice($shorts, $pos, 1, array_fill(0, 8 - ($count - 1), '0')); + $shorts = \array_pad($shorts, 8, '0'); + } else if (false !== $pos = \array_search('', $shorts, true)) { + \array_splice($shorts, $pos, 1, \array_fill(0, 8 - ($count - 1), '0')); } - $this->setShorts(array_map('hexdec', $shorts)); + $this->setShorts(\array_map('hexdec', $shorts)); } /** @@ -127,7 +127,7 @@ public function setValue($value) * * @return int[] */ - public function getShorts() + public function getShorts(): array { return $this->shorts; } @@ -140,19 +140,19 @@ public function getShorts() */ public function setShorts(array $shorts) { - if (count($shorts) !== 8) { + if (\count($shorts) !== 8) { throw new \UnexpectedValueException('Short list is not a valid IPv6 address: invalid short count'); } foreach ($shorts as &$short) { - if (strspn((string)$short, "0123456789") !== strlen($short) || $short < 0x0000 || $short > 0xffff) { + if (\strspn((string)$short, "0123456789") !== \strlen($short) || $short < 0x0000 || $short > 0xffff) { throw new \UnexpectedValueException('Short list is not a valid IPv6 address: invalid short value ' . $short); } $short = (int) $short; } - $this->shorts = array_values($shorts); + $this->shorts = \array_values($shorts); $this->value = $this->createCompressedString($this->shorts); } } diff --git a/src/Records/Types/Long.php b/src/Records/Types/Long.php index c3fa777..008c565 100644 --- a/src/Records/Types/Long.php +++ b/src/Records/Types/Long.php @@ -30,16 +30,17 @@ class Long extends Type /** * Set the internal value * - * @param int $value The new value + * @param string $value The new value * @throws \UnderflowException When the supplied value is less than 0 * @throws \OverflowException When the supplied value is greater than 4294967296 */ - public function setValue($value) + public function setValue(string $value) { $value = (int) $value; + if ($value < 0) { throw new \UnderflowException('Long integer value must be in the range 0 - 4294967296'); - } else if ($value > 4294967296) { + } else if ($value > 0xffffffff) { throw new \OverflowException('Long integer value must be in the range 0 - 4294967296'); } diff --git a/src/Records/Types/Short.php b/src/Records/Types/Short.php index 8efaaee..d4468c7 100644 --- a/src/Records/Types/Short.php +++ b/src/Records/Types/Short.php @@ -30,16 +30,17 @@ class Short extends Type /** * Set the internal value * - * @param int $value The new value + * @param string $value The new value * @throws \UnderflowException When the supplied value is less than 0 * @throws \OverflowException When the supplied value is greater than 65535 */ - public function setValue($value) + public function setValue(string $value) { $value = (int) $value; + if ($value < 0) { throw new \UnderflowException('Short integer value must be in the range 0 - 65535'); - } else if ($value > 65535) { + } else if ($value > 0xffff) { throw new \OverflowException('Short integer value must be in the range 0 - 65535'); } diff --git a/src/Records/Types/Type.php b/src/Records/Types/Type.php index 6823d00..d34e619 100644 --- a/src/Records/Types/Type.php +++ b/src/Records/Types/Type.php @@ -30,10 +30,10 @@ abstract class Type /** * Constructor * - * @param mixed $value Internal value + * @param string $value Internal value * @throws \RuntimeException When the supplied value is invalid */ - public function __construct($value = null) + public function __construct(string $value = null) { if (isset($value)) { $this->setValue($value); @@ -41,11 +41,11 @@ public function __construct($value = null) } /** - * Magic method for type coersion to string + * Magic method for type coercion to string * * @return string */ - public function __toString() + public function __toString(): string { return (string) $this->value; } @@ -63,8 +63,8 @@ public function getValue() /** * Set the internal value * - * @param mixed $value The new value + * @param string $value The new value * @throws \RuntimeException When the supplied value is invalid */ - abstract public function setValue($value); + abstract public function setValue(string $value); } diff --git a/src/Records/Types/TypeBuilder.php b/src/Records/Types/TypeBuilder.php index 4dcc6da..f5a090f 100644 --- a/src/Records/Types/TypeBuilder.php +++ b/src/Records/Types/TypeBuilder.php @@ -43,7 +43,7 @@ public function __construct(TypeFactory $typeFactory) * @param int $type Data type, can be indicated using the Types enum * @return \LibDNS\Records\Types\Type */ - public function build($type) + public function build(int $type): Type { static $typeMap = [ Types::ANYTHING => 'createAnything', diff --git a/src/Records/Types/TypeFactory.php b/src/Records/Types/TypeFactory.php index 0cf5d8b..6f42359 100644 --- a/src/Records/Types/TypeFactory.php +++ b/src/Records/Types/TypeFactory.php @@ -28,7 +28,7 @@ class TypeFactory * @param string $value * @return \LibDNS\Records\Types\Anything */ - public function createAnything($value = null) + public function createAnything(string $value = null) { return new Anything($value); } @@ -39,7 +39,7 @@ public function createAnything($value = null) * @param string $value * @return \LibDNS\Records\Types\BitMap */ - public function createBitMap($value = null) + public function createBitMap(string $value = null) { return new BitMap($value); } @@ -50,9 +50,9 @@ public function createBitMap($value = null) * @param int $value * @return \LibDNS\Records\Types\Char */ - public function createChar($value = null) + public function createChar(int $value = null) { - return new Char($value); + return new Char((string)$value); } /** @@ -61,7 +61,7 @@ public function createChar($value = null) * @param string $value * @return \LibDNS\Records\Types\CharacterString */ - public function createCharacterString($value = null) + public function createCharacterString(string $value = null) { return new CharacterString($value); } @@ -80,7 +80,7 @@ public function createDomainName($value = null) /** * Create a new IPv4Address object * - * @param string $value + * @param string|int[] $value * @return \LibDNS\Records\Types\IPv4Address */ public function createIPv4Address($value = null) @@ -91,7 +91,7 @@ public function createIPv4Address($value = null) /** * Create a new IPv6Address object * - * @param string $value + * @param string|int[] $value * @return \LibDNS\Records\Types\IPv6Address */ public function createIPv6Address($value = null) @@ -105,9 +105,9 @@ public function createIPv6Address($value = null) * @param int $value * @return \LibDNS\Records\Types\Long */ - public function createLong($value = null) + public function createLong(int $value = null) { - return new Long($value); + return new Long((string)$value); } /** @@ -116,8 +116,8 @@ public function createLong($value = null) * @param int $value * @return \LibDNS\Records\Types\Short */ - public function createShort($value = null) + public function createShort(int $value = null) { - return new Short($value); + return new Short((string)$value); } } diff --git a/src/Records/Types/Types.php b/src/Records/Types/Types.php index de84a43..337cce1 100644 --- a/src/Records/Types/Types.php +++ b/src/Records/Types/Types.php @@ -22,7 +22,7 @@ * @package Types * @author Chris Wright */ -class Types extends Enumeration +final class Types extends Enumeration { const ANYTHING = 0b000000001; const BITMAP = 0b000000010; From 61db9af3fe075fccd8d72236c81e91c61bb4e86e Mon Sep 17 00:00:00 2001 From: Chris Wright Date: Mon, 15 May 2017 21:55:00 +0100 Subject: [PATCH 05/11] Replace Iterator implementations with IteratorAggregate --- src/Records/RData.php | 52 ++--------------- src/Records/RecordCollection.php | 58 ++----------------- .../TypeDefinitions/TypeDefinition.php | 52 ++--------------- 3 files changed, 16 insertions(+), 146 deletions(-) diff --git a/src/Records/RData.php b/src/Records/RData.php index f184d08..3c71546 100644 --- a/src/Records/RData.php +++ b/src/Records/RData.php @@ -23,7 +23,7 @@ * @package Records * @author Chris Wright */ -class RData implements \Iterator, \Countable +class RData implements \IteratorAggregate, \Countable { /** * @var \LibDNS\Records\Types\Type[] The items that make up the complex type @@ -35,11 +35,6 @@ class RData implements \Iterator, \Countable */ private $typeDef; - /** - * @var bool Whether the iteration pointer has more elements to yield - */ - private $pointerValid = 0; - /** * Constructor * @@ -134,50 +129,13 @@ public function getTypeDefinition(): TypeDefinition } /** - * Get the field indicated by the iteration pointer (Iterator interface) - * - * @return \LibDNS\Records\Types\Type - */ - public function current(): Type - { - return \current($this->fields); - } - - /** - * Get the value of the iteration pointer (Iterator interface) - * - * @return int - */ - public function key(): int - { - return \key($this->fields); - } - - /** - * Increment the iteration pointer (Iterator interface) - */ - public function next() - { - $this->pointerValid = \next($this->fields) !== false; - } - - /** - * Reset the iteration pointer to the beginning (Iterator interface) - */ - public function rewind() - { - \reset($this->fields); - $this->pointerValid = \count($this->fields) > 0; - } - - /** - * Test whether the iteration pointer indicates a valid field (Iterator interface) + * Retrieve an iterator (IteratorAggregate interface) * - * @return bool + * @return \Iterator */ - public function valid(): bool + public function getIterator(): \Iterator { - return $this->pointerValid; + return new \ArrayIterator($this->fields); } /** diff --git a/src/Records/RecordCollection.php b/src/Records/RecordCollection.php index d7224c1..c7f434e 100644 --- a/src/Records/RecordCollection.php +++ b/src/Records/RecordCollection.php @@ -20,7 +20,7 @@ * @package Records * @author Chris Wright */ -class RecordCollection implements \Iterator, \Countable +class RecordCollection implements \IteratorAggregate, \Countable { /** * @var \LibDNS\Records\Record[] List of records held in the collection @@ -42,11 +42,6 @@ class RecordCollection implements \Iterator, \Countable */ private $type; - /** - * @var int Iteration pointer - */ - private $position = 0; - /** * Constructor * @@ -205,7 +200,7 @@ public function clearRecordsByName(string $name): int public function clear() { $this->records = $this->nameMap = []; - $this->length = $this->position = 0; + $this->length = 0; } /** @@ -229,54 +224,13 @@ public function getType(): int } /** - * Get the record indicated by the iteration pointer (Iterator interface) - * - * @return \LibDNS\Records\Record - * @throws \OutOfBoundsException When the pointer does not refer to a valid record - */ - public function current(): Record - { - if (!isset($this->records[$this->position])) { - throw new \OutOfBoundsException('The current pointer position is invalid'); - } - - return $this->records[$this->position]; - } - - /** - * Get the value of the iteration pointer (Iterator interface) - * - * @return int - */ - public function key(): int - { - return $this->position; - } - - /** - * Increment the iteration pointer (Iterator interface) - */ - public function next() - { - $this->position++; - } - - /** - * Reset the iteration pointer to the beginning (Iterator interface) - */ - public function rewind() - { - $this->position = 0; - } - - /** - * Test whether the iteration pointer indicates a valid record (Iterator interface) + * Retrieve an iterator (IteratorAggregate interface) * - * @return bool + * @return \Iterator */ - public function valid(): bool + public function getIterator(): \Iterator { - return isset($this->records[$this->position]); + return new \ArrayIterator($this->records); } /** diff --git a/src/Records/TypeDefinitions/TypeDefinition.php b/src/Records/TypeDefinitions/TypeDefinition.php index 151b580..e448114 100644 --- a/src/Records/TypeDefinitions/TypeDefinition.php +++ b/src/Records/TypeDefinitions/TypeDefinition.php @@ -20,7 +20,7 @@ * @package TypeDefinitions * @author Chris Wright */ -class TypeDefinition implements \Iterator, \Countable +class TypeDefinition implements \IteratorAggregate, \Countable { /** * @var FieldDefinitionFactory Creates FieldDefinition objects @@ -52,11 +52,6 @@ class TypeDefinition implements \Iterator, \Countable */ private $toStringFunction; - /** - * @var bool Whether the iteration pointer indicates a valid item - */ - private $pointerValid = true; - /** * Constructor * @@ -180,50 +175,13 @@ public function setToStringFunction(callable $function) } /** - * Get the field indicated by the iteration pointer (Iterator interface) - * - * @return \LibDNS\Records\TypeDefinitions\FieldDefinition - */ - public function current(): FieldDefinition - { - return current($this->fieldDefs); - } - - /** - * Get the key indicated by the iteration pointer - * - * @return int - */ - public function key(): int - { - return key($this->fieldDefs); - } - - /** - * Increment the iteration pointer (Iterator interface) - */ - public function next() - { - $this->pointerValid = \next($this->fieldDefs) !== false; - } - - /** - * Reset the iteration pointer to the beginning (Iterator interface) - */ - public function rewind() - { - \reset($this->fieldDefs); - $this->pointerValid = \count($this->fieldDefs) > 0; - } - - /** - * Test whether the iteration pointer indicates a valid field (Iterator interface) + * Retrieve an iterator (IteratorAggregate interface) * - * @return bool + * @return \Iterator */ - public function valid(): bool + public function getIterator(): \Iterator { - return $this->pointerValid; + return new \ArrayIterator($this->fieldDefs); } /** From 2b6be73d73ff23b96907d1026fc5000486b203cb Mon Sep 17 00:00:00 2001 From: Chris Wright Date: Mon, 15 May 2017 22:13:28 +0100 Subject: [PATCH 06/11] Handle IDN domain names --- src/Records/Types/DomainName.php | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) diff --git a/src/Records/Types/DomainName.php b/src/Records/Types/DomainName.php index 3011a44..8e98776 100644 --- a/src/Records/Types/DomainName.php +++ b/src/Records/Types/DomainName.php @@ -24,6 +24,11 @@ class DomainName extends Type { const FLAG_NO_COMPRESSION = 0x80000000; + /** + * @var callable|null + */ + private static $labelPreProcessor = null; + /** * @var string */ @@ -42,6 +47,18 @@ class DomainName extends Type */ public function __construct($value = null) { + if (!isset(self::$labelPreProcessor)) { + self::$labelPreProcessor = \function_exists('idn_to_ascii') + ? static function($label) { + if (false === $result = \idn_to_ascii($label, 0, INTL_IDNA_VARIANT_UTS46)) { + throw new \InvalidArgumentException('Label ' . $label . ' could not be processed for IDN'); + } + + return $result; + } + : 'strtolower'; + } + if (\is_array($value)) { $this->setLabels($value); } else { @@ -87,12 +104,12 @@ public function setLabels(array $labels, $tldFirst = false) $length = $count = 0; foreach ($labels as &$label) { - $labelLength = strlen($label); + $label = (self::$labelPreProcessor)($label); + $labelLength = \strlen($label); if ($labelLength > 63) { throw new \InvalidArgumentException('Label list is not a valid domain name: Label ' . $label . ' length exceeds 63 byte limit'); } $length += $labelLength + 1; - $label = \strtolower($label); $count++; } From 4c14b54f08f7ff3cd30b69caa3927bf0bd5b526d Mon Sep 17 00:00:00 2001 From: Chris Wright Date: Mon, 15 May 2017 22:32:23 +0100 Subject: [PATCH 07/11] Strict types bugfixes --- examples/AQuery.php | 2 +- src/Decoder/Decoder.php | 37 ++++++++++++++++--------------- src/Records/Types/IPv4Address.php | 2 +- 3 files changed, 21 insertions(+), 20 deletions(-) diff --git a/examples/AQuery.php b/examples/AQuery.php index 8ea7e0b..07df0e6 100644 --- a/examples/AQuery.php +++ b/examples/AQuery.php @@ -21,7 +21,7 @@ use \LibDNS\Decoder\DecoderFactory; // Config -$queryName = 'google.com'; +$queryName = 'faß.de'; $serverIP = '8.8.8.8'; $requestTimeout = 3; diff --git a/src/Decoder/Decoder.php b/src/Decoder/Decoder.php index 28e743f..f3158b5 100644 --- a/src/Decoder/Decoder.php +++ b/src/Decoder/Decoder.php @@ -13,25 +13,26 @@ */ namespace LibDNS\Decoder; -use \LibDNS\Packets\PacketFactory; -use \LibDNS\Packets\Packet; -use \LibDNS\Messages\MessageFactory; -use \LibDNS\Messages\Message; +use LibDNS\Messages\Message; +use LibDNS\Messages\MessageFactory; +use LibDNS\Packets\Packet; +use LibDNS\Packets\PacketFactory; use LibDNS\Records\Question; -use \LibDNS\Records\QuestionFactory; -use \LibDNS\Records\ResourceBuilder; -use \LibDNS\Records\Types\Type; -use \LibDNS\Records\Types\Anything; -use \LibDNS\Records\Types\BitMap; -use \LibDNS\Records\Types\Char; -use \LibDNS\Records\Types\CharacterString; -use \LibDNS\Records\Types\DomainName; -use \LibDNS\Records\Types\IPv4Address; -use \LibDNS\Records\Types\IPv6Address; -use \LibDNS\Records\Types\Long; -use \LibDNS\Records\Types\Short; -use \LibDNS\Records\Types\Types; -use \LibDNS\Records\Types\TypeBuilder; +use LibDNS\Records\QuestionFactory; +use LibDNS\Records\Resource; +use LibDNS\Records\ResourceBuilder; +use LibDNS\Records\Types\Anything; +use LibDNS\Records\Types\BitMap; +use LibDNS\Records\Types\Char; +use LibDNS\Records\Types\CharacterString; +use LibDNS\Records\Types\DomainName; +use LibDNS\Records\Types\IPv4Address; +use LibDNS\Records\Types\IPv6Address; +use LibDNS\Records\Types\Long; +use LibDNS\Records\Types\Short; +use LibDNS\Records\Types\Type; +use LibDNS\Records\Types\TypeBuilder; +use LibDNS\Records\Types\Types; /** * Decodes raw network data to Message objects diff --git a/src/Records/Types/IPv4Address.php b/src/Records/Types/IPv4Address.php index 7362e43..395b2fa 100644 --- a/src/Records/Types/IPv4Address.php +++ b/src/Records/Types/IPv4Address.php @@ -81,7 +81,7 @@ public function setOctets(array $octets) } foreach ($octets as &$octet) { - if (\strspn((string)$octet, "0123456789") !== \strlen($octet) || $octet < 0x00 || $octet > 0xff) { + if (\strspn((string)$octet, "0123456789") !== \strlen((string)$octet) || $octet < 0x00 || $octet > 0xff) { throw new \UnexpectedValueException('Octet list is not a valid IPv4 address: invalid octet value ' . $octet); } From 44962c9f97e40103084c474b1adaa7d2b57884ac Mon Sep 17 00:00:00 2001 From: Chris Wright Date: Mon, 15 May 2017 22:53:38 +0100 Subject: [PATCH 08/11] Loosen types, better error handling when IDN unavailable --- src/Records/Types/Anything.php | 4 +++- src/Records/Types/BitMap.php | 4 ++-- src/Records/Types/Char.php | 2 +- src/Records/Types/CharacterString.php | 4 +++- src/Records/Types/DomainName.php | 17 +++++++++++++---- src/Records/Types/IPv4Address.php | 4 ++-- src/Records/Types/IPv6Address.php | 4 ++-- src/Records/Types/Long.php | 4 ++-- src/Records/Types/Short.php | 4 ++-- src/Records/Types/Type.php | 2 +- 10 files changed, 31 insertions(+), 18 deletions(-) diff --git a/src/Records/Types/Anything.php b/src/Records/Types/Anything.php index e334764..8ea45ab 100644 --- a/src/Records/Types/Anything.php +++ b/src/Records/Types/Anything.php @@ -33,8 +33,10 @@ class Anything extends Type * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is outside the valid length range 0 - 65535 */ - public function setValue(string $value) + public function setValue($value) { + $value = (string)$value; + if (\strlen($value) > 65535) { throw new \UnexpectedValueException('Untyped string length must be in the range 0 - 65535'); } diff --git a/src/Records/Types/BitMap.php b/src/Records/Types/BitMap.php index ced2cf2..a10c72c 100644 --- a/src/Records/Types/BitMap.php +++ b/src/Records/Types/BitMap.php @@ -32,9 +32,9 @@ class BitMap extends Type * * @param string $value The new value */ - public function setValue(string $value) + public function setValue($value) { - $this->value = $value; + $this->value = (string)$value; } /** diff --git a/src/Records/Types/Char.php b/src/Records/Types/Char.php index bbc4e8e..aa0c51e 100644 --- a/src/Records/Types/Char.php +++ b/src/Records/Types/Char.php @@ -34,7 +34,7 @@ class Char extends Type * @throws \UnderflowException When the supplied value is less than 0 * @throws \OverflowException When the supplied value is greater than 255 */ - public function setValue(string $value) + public function setValue($value) { $value = (int) $value; diff --git a/src/Records/Types/CharacterString.php b/src/Records/Types/CharacterString.php index f40ecf2..1b55fc2 100644 --- a/src/Records/Types/CharacterString.php +++ b/src/Records/Types/CharacterString.php @@ -33,8 +33,10 @@ class CharacterString extends Type * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is outside the valid length range 0 - 255 */ - public function setValue(string $value) + public function setValue($value) { + $value = (string)$value; + if (\strlen($value) > 255) { throw new \UnexpectedValueException('Character string length must be in the range 0 - 255'); } diff --git a/src/Records/Types/DomainName.php b/src/Records/Types/DomainName.php index 8e98776..507466b 100644 --- a/src/Records/Types/DomainName.php +++ b/src/Records/Types/DomainName.php @@ -51,12 +51,21 @@ public function __construct($value = null) self::$labelPreProcessor = \function_exists('idn_to_ascii') ? static function($label) { if (false === $result = \idn_to_ascii($label, 0, INTL_IDNA_VARIANT_UTS46)) { - throw new \InvalidArgumentException('Label ' . $label . ' could not be processed for IDN'); + throw new \InvalidArgumentException("Label '{$label}' could not be processed for IDN"); } return $result; } - : 'strtolower'; + : static function($label) { + if (\preg_match('/[\x80-\xff]/', $label)) { + throw new \RuntimeException( + "Label '{$label}' contains non-ASCII characters and IDN support is not available." + . " Verify that ext/intl is installed for IDN support." + ); + } + + return \strtolower($label); + }; } if (\is_array($value)) { @@ -72,9 +81,9 @@ public function __construct($value = null) * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is not a valid domain name */ - public function setValue(string $value) + public function setValue($value) { - $this->setLabels(\explode('.', $value)); + $this->setLabels(\explode('.', (string)$value)); } /** diff --git a/src/Records/Types/IPv4Address.php b/src/Records/Types/IPv4Address.php index 395b2fa..66657f4 100644 --- a/src/Records/Types/IPv4Address.php +++ b/src/Records/Types/IPv4Address.php @@ -53,9 +53,9 @@ public function __construct($value = null) * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is outside the valid length range 0 - 65535 */ - public function setValue(string $value) + public function setValue($value) { - $this->setOctets(\explode('.', $value)); + $this->setOctets(\explode('.', (string)$value)); } /** diff --git a/src/Records/Types/IPv6Address.php b/src/Records/Types/IPv6Address.php index b4979a0..e2ca5af 100644 --- a/src/Records/Types/IPv6Address.php +++ b/src/Records/Types/IPv6Address.php @@ -104,9 +104,9 @@ public function __construct($value = null) * @param string $value The new value * @throws \UnexpectedValueException When the supplied value is outside the valid length range 0 - 65535 */ - public function setValue(string $value) + public function setValue($value) { - $shorts = \explode(':', $value); + $shorts = \explode(':', (string)$value); $count = \count($shorts); if ($count < 3 || $count > 8) { diff --git a/src/Records/Types/Long.php b/src/Records/Types/Long.php index 008c565..5ba9361 100644 --- a/src/Records/Types/Long.php +++ b/src/Records/Types/Long.php @@ -34,9 +34,9 @@ class Long extends Type * @throws \UnderflowException When the supplied value is less than 0 * @throws \OverflowException When the supplied value is greater than 4294967296 */ - public function setValue(string $value) + public function setValue($value) { - $value = (int) $value; + $value = (int)$value; if ($value < 0) { throw new \UnderflowException('Long integer value must be in the range 0 - 4294967296'); diff --git a/src/Records/Types/Short.php b/src/Records/Types/Short.php index d4468c7..27a235a 100644 --- a/src/Records/Types/Short.php +++ b/src/Records/Types/Short.php @@ -34,9 +34,9 @@ class Short extends Type * @throws \UnderflowException When the supplied value is less than 0 * @throws \OverflowException When the supplied value is greater than 65535 */ - public function setValue(string $value) + public function setValue($value) { - $value = (int) $value; + $value = (int)$value; if ($value < 0) { throw new \UnderflowException('Short integer value must be in the range 0 - 65535'); diff --git a/src/Records/Types/Type.php b/src/Records/Types/Type.php index d34e619..78e56e8 100644 --- a/src/Records/Types/Type.php +++ b/src/Records/Types/Type.php @@ -66,5 +66,5 @@ public function getValue() * @param string $value The new value * @throws \RuntimeException When the supplied value is invalid */ - abstract public function setValue(string $value); + abstract public function setValue($value); } From 961d61ef804d9cc8f2408f7de62eee3165203e58 Mon Sep 17 00:00:00 2001 From: Chris Wright Date: Mon, 22 May 2017 16:47:57 +0100 Subject: [PATCH 09/11] Add and use public normalize_name() function --- composer.json | 3 ++- src/Records/Types/DomainName.php | 28 +--------------------------- src/functions.php | 26 ++++++++++++++++++++++++++ 3 files changed, 29 insertions(+), 28 deletions(-) create mode 100644 src/functions.php diff --git a/composer.json b/composer.json index 6509ee1..4371af7 100644 --- a/composer.json +++ b/composer.json @@ -9,7 +9,8 @@ "autoload": { "psr-4": { "LibDNS\\": "src/" - } + }, + "files": ["src/functions.php"] }, "support": { "issues": "https://github.com/DaveRandom/LibDNS/issues" diff --git a/src/Records/Types/DomainName.php b/src/Records/Types/DomainName.php index 507466b..d9b1a8f 100644 --- a/src/Records/Types/DomainName.php +++ b/src/Records/Types/DomainName.php @@ -24,11 +24,6 @@ class DomainName extends Type { const FLAG_NO_COMPRESSION = 0x80000000; - /** - * @var callable|null - */ - private static $labelPreProcessor = null; - /** * @var string */ @@ -47,27 +42,6 @@ class DomainName extends Type */ public function __construct($value = null) { - if (!isset(self::$labelPreProcessor)) { - self::$labelPreProcessor = \function_exists('idn_to_ascii') - ? static function($label) { - if (false === $result = \idn_to_ascii($label, 0, INTL_IDNA_VARIANT_UTS46)) { - throw new \InvalidArgumentException("Label '{$label}' could not be processed for IDN"); - } - - return $result; - } - : static function($label) { - if (\preg_match('/[\x80-\xff]/', $label)) { - throw new \RuntimeException( - "Label '{$label}' contains non-ASCII characters and IDN support is not available." - . " Verify that ext/intl is installed for IDN support." - ); - } - - return \strtolower($label); - }; - } - if (\is_array($value)) { $this->setLabels($value); } else { @@ -113,7 +87,7 @@ public function setLabels(array $labels, $tldFirst = false) $length = $count = 0; foreach ($labels as &$label) { - $label = (self::$labelPreProcessor)($label); + $label = \LibDNS\normalize_name($label); $labelLength = \strlen($label); if ($labelLength > 63) { throw new \InvalidArgumentException('Label list is not a valid domain name: Label ' . $label . ' length exceeds 63 byte limit'); diff --git a/src/functions.php b/src/functions.php new file mode 100644 index 0000000..cdb5ab2 --- /dev/null +++ b/src/functions.php @@ -0,0 +1,26 @@ + Date: Mon, 22 May 2017 16:55:58 +0100 Subject: [PATCH 10/11] Suggest ext/intl in composer --- composer.json | 3 +++ 1 file changed, 3 insertions(+) diff --git a/composer.json b/composer.json index 4371af7..968efe2 100644 --- a/composer.json +++ b/composer.json @@ -14,5 +14,8 @@ }, "support": { "issues": "https://github.com/DaveRandom/LibDNS/issues" + }, + "suggest": { + "ext-intl": "Required for IDN support" } } From d98d294ff87cb4a6e15d60f72b88467eb52a28b5 Mon Sep 17 00:00:00 2001 From: Michael Maroszek Date: Fri, 9 Jun 2017 14:19:36 +0200 Subject: [PATCH 11/11] fix encoding of response types --- src/Encoder/Encoder.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Encoder/Encoder.php b/src/Encoder/Encoder.php index fae7ad8..f8bc7a2 100644 --- a/src/Encoder/Encoder.php +++ b/src/Encoder/Encoder.php @@ -78,7 +78,7 @@ private function encodeHeader(EncodingContext $encodingContext, Message $message 'ar' => $message->getAdditionalRecords()->count() ]; - $header['meta'] |= $message->getType() << 16; + $header['meta'] |= $message->getType() << 15; $header['meta'] |= $message->getOpCode() << 11; $header['meta'] |= ((int) $message->isAuthoritative()) << 10; $header['meta'] |= ((int) $encodingContext->isTruncated()) << 9;