a50/clock

PSR-20 ClockInterface implementation

Maintainers

Details

github.com/a50dev/clock

Source

Issues

Installs: 2 009

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Open Issues: 0

Type:project

v1.0.1 2024-05-10 05:00 UTC

This package is auto-updated.

Last update: 2024-12-10 06:32:37 UTC


README

A50 Clock


This package provides an implementation of the PSR-20 ClockInterface.

Latest Version on Packagist Tests Analysis Total Downloads

Installation

You can install the package via composer:

composer require a50/clock

Usage

Pass ClockInterface to the method in which you want to get the current date in the desired time zone:

<?php

declare(strict_types=1);

namespace Project\Reviews\Application\AddReview;

use Psr\Clock\ClockInterface;
use Project\Reviews\Domain\Review;
// ...

final class Handler
{
    private ClockInterface $clock;

    public function __construct(
        ClockInterface $clock,
        // ...
    ) {
        $this->clock = $clock;
        // ...
    }

    public function __invoke(Command $command): void
    {
        $review = Review::add(
            // ...
            $this->clock->now(),
        );

        // ...
    }
}

or use the right one directly:

<?php

declare(strict_types=1);

$clock = new TimeZoneAwareClock(new DateTimeZone('Europe/Minsk'));
$now = $clock->now();

If you use the ClockServiceProvider then the default ClockInterface is implemented by TimeZoneAwareClock with UTC timezone.

You can change the timezone by setting it in the config settings.

<?php

declare(strict_types=1);

use A50\Container\ServiceProvider;
use A50\Clock\ClockConfig;

new class implements ServiceProvider {
    
    // ...

    /**
     * @inheritDoc
     */
    public static function getExtensions(): array
    {
        return [
            ClockConfig::class => static function ($config, ContainerInterface $container): stdClass {
                $config->withTimezone('Europe/Minsk');

                return $config;
            }
        ];
    }
}

Testing

make test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.