mirror of
https://github.com/shlinkio/shlink.git
synced 2025-02-25 18:45:27 -06:00
Make classes readonly when possible
This commit is contained in:
parent
d6b103de83
commit
72f1e243b5
@ -11,7 +11,7 @@ use Symfony\Component\Console\Output\OutputInterface;
|
|||||||
|
|
||||||
use function sprintf;
|
use function sprintf;
|
||||||
|
|
||||||
readonly final class EndDateOption
|
final readonly class EndDateOption
|
||||||
{
|
{
|
||||||
private DateOption $dateOption;
|
private DateOption $dateOption;
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ use function array_unique;
|
|||||||
use function Shlinkio\Shlink\Core\ArrayUtils\flatten;
|
use function Shlinkio\Shlink\Core\ArrayUtils\flatten;
|
||||||
use function Shlinkio\Shlink\Core\splitByComma;
|
use function Shlinkio\Shlink\Core\splitByComma;
|
||||||
|
|
||||||
readonly final class ShortUrlDataInput
|
final readonly class ShortUrlDataInput
|
||||||
{
|
{
|
||||||
public function __construct(Command $command, private bool $longUrlAsOption = false)
|
public function __construct(Command $command, private bool $longUrlAsOption = false)
|
||||||
{
|
{
|
||||||
|
@ -10,7 +10,7 @@ use Symfony\Component\Console\Input\InputArgument;
|
|||||||
use Symfony\Component\Console\Input\InputInterface;
|
use Symfony\Component\Console\Input\InputInterface;
|
||||||
use Symfony\Component\Console\Input\InputOption;
|
use Symfony\Component\Console\Input\InputOption;
|
||||||
|
|
||||||
readonly final class ShortUrlIdentifierInput
|
final readonly class ShortUrlIdentifierInput
|
||||||
{
|
{
|
||||||
public function __construct(Command $command, string $shortCodeDesc, string $domainDesc)
|
public function __construct(Command $command, string $shortCodeDesc, string $domainDesc)
|
||||||
{
|
{
|
||||||
|
@ -11,7 +11,7 @@ use Symfony\Component\Console\Output\OutputInterface;
|
|||||||
|
|
||||||
use function sprintf;
|
use function sprintf;
|
||||||
|
|
||||||
readonly final class StartDateOption
|
final readonly class StartDateOption
|
||||||
{
|
{
|
||||||
private DateOption $dateOption;
|
private DateOption $dateOption;
|
||||||
|
|
||||||
|
@ -6,9 +6,9 @@ namespace Shlinkio\Shlink\Core\Crawling;
|
|||||||
|
|
||||||
use Shlinkio\Shlink\Core\ShortUrl\Repository\CrawlableShortCodesQueryInterface;
|
use Shlinkio\Shlink\Core\ShortUrl\Repository\CrawlableShortCodesQueryInterface;
|
||||||
|
|
||||||
class CrawlingHelper implements CrawlingHelperInterface
|
readonly class CrawlingHelper implements CrawlingHelperInterface
|
||||||
{
|
{
|
||||||
public function __construct(private readonly CrawlableShortCodesQueryInterface $query)
|
public function __construct(private CrawlableShortCodesQueryInterface $query)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,12 +9,12 @@ use Shlinkio\Shlink\Core\Config\NotFoundRedirectConfigInterface;
|
|||||||
use Shlinkio\Shlink\Core\Config\NotFoundRedirects;
|
use Shlinkio\Shlink\Core\Config\NotFoundRedirects;
|
||||||
use Shlinkio\Shlink\Core\Domain\Entity\Domain;
|
use Shlinkio\Shlink\Core\Domain\Entity\Domain;
|
||||||
|
|
||||||
final class DomainItem implements JsonSerializable
|
final readonly class DomainItem implements JsonSerializable
|
||||||
{
|
{
|
||||||
private function __construct(
|
private function __construct(
|
||||||
private readonly string $authority,
|
private string $authority,
|
||||||
public readonly NotFoundRedirectConfigInterface $notFoundRedirectConfig,
|
public NotFoundRedirectConfigInterface $notFoundRedirectConfig,
|
||||||
public readonly bool $isDefault,
|
public bool $isDefault,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,9 +11,9 @@ use Shlinkio\Shlink\Core\Visit\Model\VisitType;
|
|||||||
|
|
||||||
use function rtrim;
|
use function rtrim;
|
||||||
|
|
||||||
class NotFoundType
|
readonly class NotFoundType
|
||||||
{
|
{
|
||||||
private function __construct(private readonly VisitType|null $type)
|
private function __construct(private VisitType|null $type)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -13,11 +13,11 @@ use Shlinkio\Shlink\Core\Visit\Geolocation\VisitLocatorInterface;
|
|||||||
use Shlinkio\Shlink\Core\Visit\Geolocation\VisitToLocationHelperInterface;
|
use Shlinkio\Shlink\Core\Visit\Geolocation\VisitToLocationHelperInterface;
|
||||||
use Shlinkio\Shlink\IpGeolocation\Model\Location;
|
use Shlinkio\Shlink\IpGeolocation\Model\Location;
|
||||||
|
|
||||||
class LocateUnlocatedVisits implements VisitGeolocationHelperInterface
|
readonly class LocateUnlocatedVisits implements VisitGeolocationHelperInterface
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly VisitLocatorInterface $locator,
|
private VisitLocatorInterface $locator,
|
||||||
private readonly VisitToLocationHelperInterface $visitToLocation,
|
private VisitToLocationHelperInterface $visitToLocation,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -13,12 +13,12 @@ use Throwable;
|
|||||||
|
|
||||||
use function sprintf;
|
use function sprintf;
|
||||||
|
|
||||||
class UpdateGeoLiteDb
|
readonly class UpdateGeoLiteDb
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly GeolocationDbUpdaterInterface $dbUpdater,
|
private GeolocationDbUpdaterInterface $dbUpdater,
|
||||||
private readonly LoggerInterface $logger,
|
private LoggerInterface $logger,
|
||||||
private readonly EventDispatcherInterface $eventDispatcher,
|
private EventDispatcherInterface $eventDispatcher,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,14 +25,14 @@ use function implode;
|
|||||||
use function sprintf;
|
use function sprintf;
|
||||||
use function trim;
|
use function trim;
|
||||||
|
|
||||||
class ExtraPathRedirectMiddleware implements MiddlewareInterface
|
readonly class ExtraPathRedirectMiddleware implements MiddlewareInterface
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly ShortUrlResolverInterface $resolver,
|
private ShortUrlResolverInterface $resolver,
|
||||||
private readonly RequestTrackerInterface $requestTracker,
|
private RequestTrackerInterface $requestTracker,
|
||||||
private readonly ShortUrlRedirectionBuilderInterface $redirectionBuilder,
|
private ShortUrlRedirectionBuilderInterface $redirectionBuilder,
|
||||||
private readonly RedirectResponseHelperInterface $redirectResponseHelper,
|
private RedirectResponseHelperInterface $redirectResponseHelper,
|
||||||
private readonly UrlShortenerOptions $urlShortenerOptions,
|
private UrlShortenerOptions $urlShortenerOptions,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,11 +7,11 @@ namespace Shlinkio\Shlink\Core\ShortUrl\Model;
|
|||||||
use Shlinkio\Shlink\Core\ShortUrl\Entity\ShortUrl;
|
use Shlinkio\Shlink\Core\ShortUrl\Entity\ShortUrl;
|
||||||
use Throwable;
|
use Throwable;
|
||||||
|
|
||||||
final class UrlShorteningResult
|
final readonly class UrlShorteningResult
|
||||||
{
|
{
|
||||||
private function __construct(
|
private function __construct(
|
||||||
public readonly ShortUrl $shortUrl,
|
public ShortUrl $shortUrl,
|
||||||
private readonly Throwable|null $errorOnEventDispatching,
|
private Throwable|null $errorOnEventDispatching,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,11 +10,11 @@ use Shlinkio\Shlink\Core\ShortUrl\Model\ShortUrlIdentifier;
|
|||||||
use Shlinkio\Shlink\Core\Visit\Repository\VisitDeleterRepositoryInterface;
|
use Shlinkio\Shlink\Core\Visit\Repository\VisitDeleterRepositoryInterface;
|
||||||
use Shlinkio\Shlink\Rest\Entity\ApiKey;
|
use Shlinkio\Shlink\Rest\Entity\ApiKey;
|
||||||
|
|
||||||
class ShortUrlVisitsDeleter implements ShortUrlVisitsDeleterInterface
|
readonly class ShortUrlVisitsDeleter implements ShortUrlVisitsDeleterInterface
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly VisitDeleterRepositoryInterface $repository,
|
private VisitDeleterRepositoryInterface $repository,
|
||||||
private readonly ShortUrlResolverInterface $resolver,
|
private ShortUrlResolverInterface $resolver,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,9 +10,9 @@ use Shlinkio\Shlink\Core\Config\Options\RedirectOptions;
|
|||||||
|
|
||||||
use function sprintf;
|
use function sprintf;
|
||||||
|
|
||||||
class RedirectResponseHelper implements RedirectResponseHelperInterface
|
readonly class RedirectResponseHelper implements RedirectResponseHelperInterface
|
||||||
{
|
{
|
||||||
public function __construct(private readonly RedirectOptions $options)
|
public function __construct(private RedirectOptions $options)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,11 +11,11 @@ use Shlinkio\Shlink\Core\Visit\Entity\VisitLocation;
|
|||||||
use Shlinkio\Shlink\Core\Visit\Repository\VisitIterationRepositoryInterface;
|
use Shlinkio\Shlink\Core\Visit\Repository\VisitIterationRepositoryInterface;
|
||||||
use Shlinkio\Shlink\IpGeolocation\Model\Location;
|
use Shlinkio\Shlink\IpGeolocation\Model\Location;
|
||||||
|
|
||||||
class VisitLocator implements VisitLocatorInterface
|
readonly class VisitLocator implements VisitLocatorInterface
|
||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly EntityManagerInterface $em,
|
private EntityManagerInterface $em,
|
||||||
private readonly VisitIterationRepositoryInterface $repo,
|
private VisitIterationRepositoryInterface $repo,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,9 +11,9 @@ use Shlinkio\Shlink\IpGeolocation\Exception\WrongIpException;
|
|||||||
use Shlinkio\Shlink\IpGeolocation\Model\Location;
|
use Shlinkio\Shlink\IpGeolocation\Model\Location;
|
||||||
use Shlinkio\Shlink\IpGeolocation\Resolver\IpLocationResolverInterface;
|
use Shlinkio\Shlink\IpGeolocation\Resolver\IpLocationResolverInterface;
|
||||||
|
|
||||||
class VisitToLocationHelper implements VisitToLocationHelperInterface
|
readonly class VisitToLocationHelper implements VisitToLocationHelperInterface
|
||||||
{
|
{
|
||||||
public function __construct(private readonly IpLocationResolverInterface $ipLocationResolver)
|
public function __construct(private IpLocationResolverInterface $ipLocationResolver)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,9 +9,9 @@ use Shlinkio\Shlink\Core\Visit\Repository\VisitDeleterRepositoryInterface;
|
|||||||
use Shlinkio\Shlink\Rest\ApiKey\Role;
|
use Shlinkio\Shlink\Rest\ApiKey\Role;
|
||||||
use Shlinkio\Shlink\Rest\Entity\ApiKey;
|
use Shlinkio\Shlink\Rest\Entity\ApiKey;
|
||||||
|
|
||||||
class VisitsDeleter implements VisitsDeleterInterface
|
readonly class VisitsDeleter implements VisitsDeleterInterface
|
||||||
{
|
{
|
||||||
public function __construct(private readonly VisitDeleterRepositoryInterface $repository)
|
public function __construct(private VisitDeleterRepositoryInterface $repository)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user