50 lines
1.5 KiB
PHP
50 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace Pterodactyl\Rules;
|
|
|
|
use Illuminate\Contracts\Validation\Rule;
|
|
|
|
class ResolvesToIPAddress implements Rule
|
|
{
|
|
/**
|
|
* Validate that a given string can correctly resolve to a valid IPv4 address.
|
|
*
|
|
* @param string $attribute
|
|
* @param mixed $value
|
|
* @return bool
|
|
*/
|
|
public function passes($attribute, $value): bool
|
|
{
|
|
// inet_pton returns false if the value passed through is not a valid IP address, so we'll just
|
|
// use that a nice ugly PHP hack to determine if we should pass this off to the gethostbyname
|
|
// call below.
|
|
$isIP = inet_pton($attribute) !== false;
|
|
|
|
// If the value received is not an IP address try to look it up using the gethostbyname() call.
|
|
// If that returns the same value that we passed in then it means it did not resolve to anything
|
|
// and we should fail this validation call.
|
|
return $isIP || gethostbyname($value) !== $value;
|
|
}
|
|
|
|
/**
|
|
* Return a validation message for use when this rule fails.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function message(): string
|
|
{
|
|
return 'The :attribute must be a valid IPv4 address or hostname that resolves to a valid IPv4 address.';
|
|
}
|
|
|
|
/**
|
|
* Convert the rule to a validation string. This is necessary to avoid
|
|
* issues with Eloquence which tries to use this rule as a string.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function __toString()
|
|
{
|
|
return 'p_resolves_to_ip_address';
|
|
}
|
|
}
|