The League of Extraordinary Packages

Our Packages:

Presented by The League of Extraordinary Packages

Getting Started


Upgrading Guide

This is the documentation for the upcoming version 4.0. This is a work in progress


Author Latest Version Software License Build Status Total Downloads

Period is PHP’s missing time range API. It is based on Resolving Feature Envy in the Domain by Mathias Verraes and extends the concept to cover all basic operations regarding time ranges.


Of note, in your code, you will always have to typehint against the League\Period\Period class directly. Because League\Period\Period is a immutable value object class, the class is marked as final and does not provide an interface.

Accessing time range properties



use League\Period\Period;

$period = new Period(new DateTime('2014-10-03 08:12:37'), new DateTimeImmutable('2014-10-03 08:12:37'));
$start = $period->getStartDate(); //return DateTimeImmutable('2014-10-03 08:12:37');
$end   = $period->getEndDate();   //return DateTimeImmutable('2014-10-03 09:12:37');
$duration  = $period->getDateInterval();      //return a DateInterval object
$duration2 = $period->getTimestampInterval(); //return the same interval expressed in seconds.
echo $period; //displays '2014-10-03T08:12:37Z/014-10-03T09:12:37Z'

Learn more about how this all works in the basic usage.

Iterate over a time range

A simple example on how to get all the days from a selected month.

$period = new Period(new DateTime('2014-10-01'), new DateTimeImmutable('2014-11-01'));
foreach ($period->getDatePeriod(new DateInterval('P1D')) as $day) {

To help easily instantiate your time range, the package comes bundle with many helper functions.

Comparing time ranges


use function League\Period\interval_after;
use function League\Period\iso_week;

$period = interval_after('2014-01-01', '1 WEEK');
$altPeriod = iso_week(2014, 3);
$period->durationEquals($altPeriod); //will return true because the duration are equals
$period->equals($altPeriod);         //will return false because the datepoints differ

The class comes with other ways to compare time ranges based on their duration and/or their datepoints.

Modifying time ranges


use function League\Period\interval_after;

$period = interval_after('2014-01-01', '1 WEEK');
$altPeriod = $period->endingOn('2014-02-03');
$period->contains($altPeriod); //return false;
$altPeriod->durationGreaterThan($period); //return true;

Period is an immutable value object. Any changes to the object returns a new object. The class has more modifying methods.