Category Archives: PHP

Happy Birthday PHP

Today is a very personal day that is deeply connected with the programming language thatI use most – I could even say “love”.

On this day 30 years ago a certain Rasmus Lerdorf made his Personal HomePage tools publicly available. The birth of a language that should change the WorldWideWeb – conincidentally invented by a person that celebrates their birthday on exactly this day!

In these last 30 days PHP has become the programming language powering the majority of public websites – ask 3 different surveys and you’ll probably get 4 different percentage values. But all of them state that PHP is the by far most used language.

PHP has reduced the entry barrier for (web) development significantly which is probably one of the most underrated things that PHP did for programming in those last 30 years.

And due to that a lot of people started programming and were able to throw together something that worked. A lot of those people in the early days had probably not a background in programming. They did a lot of things… differently. Probably even wrong. Which also led to a lot of security issues. Which is why to this day PHP has a bad reputation of being slow and insecure and is by a lot of people not considered a “real” programming language.

And so for 30 years now people are regularly referring to PHP as a “dead language”. But well… a creaking door hangs longest…

One of the things that also developed in these 30 years is a vivid community around the language.

I first came into contact with it in form of a mailing list in 2001. And little did I know where that would lead me.

It allowed me to learn programming – first by asking questions – soon realizing that I was even able to answer some of the questions. Which allowed me to dive deeper into programming in my first real job. Which brought me into contact with more and more people from the local community. It even introduced me to my local usergroup around 2011.

And from that point on there was no turning back. I was thrown into co-organizing our local usergroup. And I realized that it would be really awesome to be able to visit other usergroups. But there wasn’t a list of other usergroups. So … I had to scratch my itch and build a list, hadn’t I?

And gosh that exploded…

It brought me into contact with so many more amazing people and opened doors that I am absolutely grateful for! It even caused me to submit a talk to a conference because a fried I made via the usergroup-organizer chat thought I should. So in 2015 I got accepted and spoke for the very first time at a PHP conference. And suddenly I stood there beneath all those big names in the PHP-community – and it turned out they were mere mortals and we had a great time!

But – and here the sad part starts – 2015 was the year that my better half got diagnosed with cancer. And due to her chemotherapy (and a change in it that required a weekly dosage) she wasn’t able to join me in this experience.

She went through it and everything was fine again.

Until on this day 5 years ago. On the 8th of June. We got the diagnose that the bastard was back again!

And when I publicly wrote about it, the PHP community did again the for me unexpected. The wave of support that hit me was overwhelming. I still sometimes have trouble understanding it! But you are all amazing!

So celebrating 30 years of PHP for me is so much more than celebrating the birth of a programming language.

It is celebrating the birth of a community that carried the Personal Homepage Tools of some quirky greenland-born guy to one of the cornerstones of the WorldWideWeb and beyond.

It is celebrating a Community that has supported me in so many ways that I can’t describe.

It is celebrating a community that connects people from all over the world in a family-kind of way (Yes that also includes the odd uncle that will always pop up somewhere).

And personally I celebrate a community that has carried and supported me through 10 years of every now and then tough times. And that has brought me a lot of friendships that I do not want to miss!

Thank you Rasmus for sparking this!

Repeating events in ICS files

I am a huge fan of ICS files!

There! I said it!

ICS files (or iCalendar files) are the exchange-format for calendaring informations.

Whenever you need to transport calendaring information (Events, Todos, Free/Busy time) they are the way to go.

ICS files are defined in RFC 5545 with some additions in RFC 7986 and. a pretty good summary at iCalendar.org

The big trouble though in ran into with ICS files is the … interesting … interpretation and implementation of the standard. And yes: XKCD 927 comes to mind!

So whenever I want to use one of the lesser used features in ICS I create a test-file and import that into several calendaring tools out there. Namely Google Calendar, Outlook, Apples iCal, Thunderbird and Teamup.com

Continue reading Repeating events in ICS files

Deploy using git archive

When deploying code I by now almost always use git archive for that no matter whether that is library code or actually product code that gets deployed onto a (web)server.

Recently I had a chat with someone that so far hadn’t heard of that so I realized perhaps it’s time to write about it.

What is it

git archive is a tool that exports the content of a git repository into an archive file. But while doing so it also uses information in a .gitattributes file to decide whether to include a file into the archive or not and also whether to modify a file.

A lot of people already know about the .gitattributes file as it makes sure that certain files are removed from the archive that is created by github when creating a release.

The documentation for .gitattributes has (amongst a huge number of other information and awesome things that can be done via that file – but that’s for some other time) a special part about creating archives that talks about two attributes:

Continue reading Deploy using git archive

ICU in PHP-images from Docker-Hub

Recently I was preparing a talk for the fwdays PHP in Kyiv. A talk about internationalization. And gues what: One of the parts of internationalization is: Timezones. Yes, I know, I am fond of them and all but that’s not what this is going to be about.

In the talk I am showing how to propperly render a datetime for a given locale in a given timezone using the IntlDateFormatter. As the talk will be in Kyiv I thought it’s only fair to use the Europe/Kyiv timezone.

The timezone Europe/Kyiv is a rather new one and was introduced in 2022 when the former timezone Europe/Kiev was renamed to Europe/Kyiv as that by now was the more widely used international spelling of the Ukrainian capital (Thank you, Vladimir, for making the world aware that the russian transcription isn’t the correct one!!)

So I added my example and thought I’d better run it through a current PHP-Version to check wether my code is actually sane and runs.

As the ICU-extension is not by default part of the images on docker-hub I created this little Dockerfile to get an image with the ICU extension:

FROM php:8.3-rc-fpm
MAINTAINER andreas@stella-maris.solutions

RUN apt-get update \
 && apt-get install -y libicu-dev \
 && docker-php-ext-configure intl --enable-intl \
 && docker-php-ext-install -j$(nproc) intl \

It’s using the latest PHP 8.3 image and adds the ICU extension. Yes! it’s not slim, there is cleanup missing etc but that is not the point here, it’s just to demonstrate something.

I created a container via docker build -t icutest .

So now let’s check the ICU version.

$ docker run icutest bash -c "php -i | grep -i icu"
ICU version => 72.1
ICU Data version => 72.1
ICU TZData version => 2022e
ICU Unicode version => 15.0
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

Wait! ICU TZData version => 2022e?

As https://data.iana.org/time-zones/tzdb-2022e/ shows, that’s from October 2022! What the heck?

What’s the timezone-DB version that PHPs DateTime lib uses?

$ docker run icutest bash -c "php -i | grep -i Olson"
"Olson" Timezone Database Version => 2024.1

Oh! Great!

So we learn different things here:

PHP libraries use separate timezone-data

The DateTime extension (you know: date, DateTimeImmutable etc) use the latest timezone-db version available at compile time of the PHP-library. (Thank you Derick for that!) One of the reasons why one should stay up-to-date with PHP-versions. If that’s not possible, you can use the timezonedb pecl-package.

But the Intl Extension – as it is a wrapper around the ICU4C library – uses it’s own timezone database. Also the last one available at release time of the library.

So why do we have a mismatch there? Because at the time of writing the current release of ICU is 75.1 – and not 72.1 as the output of PHP-info shows.

The issue I am running into here is that I installed the libicu-dev package when building the container. And that installs the – by now outdated – ICU data as debian/ubuntu do not update those packages to higher major versions. An upgrade to a higher major version of a lib only happens when updating Debian/Ubuntu to a higher Major.

Despite the fact that neither Debian/Ubuntu nor ICU are using Semantic Versioning…

Don’t come with a problem!

OK. I now had analyzed the problem (my main problem was that the code didn’t run because I was using the bullseye image and not the bookworm one which is on an even older timezone DB that didn’t know Europe/Kyiv as it was from 2019…).

How to fix it?

Well, the solution seems simple: Update the ICU extension…

So I fiddled a bit around and updated another library to handle the non-semver versioning that ICU uses and ended up with this somewhat more complex Dockerfile

What happens here

Let’s shortly go through the dockerfile

In line 5 I install stuff that is necessary for compiling code as I will need to do that with the ICU lib.

In line 6 I download the latest version of the ICU4C library. It uses getlatestassets that will make sure that we will always get the latest relerased version. Sadly the github API doesn’t provide a way to do that out of the box, so I have to use getlatestassets.com here. To make handling easier I store the archive in a file consitently named icu.tgz

The next steps are to extract the archive and change the working directory.

In line 9 I set the LIBDIR variable from what is set for PHP so that the ICU library will afterwards be placed in the right folder where PHP expects all the libs to be. Otherwise I get some odd runtime errors when PHP tries to load a library that is not available.

In line 10 I tell the config script where to put that library file and then it’s make and make install to build and install the library.

Afterwards I remove the archive file. In a production image I’d do some more cleanup here to get the imagesize down.

After that it’s the same commands that I already used in the old Dockerfile, just this time the “correct” library-version will be used.

So let’s create and check the container:

Great! Now we have a current version of ICU with a rather recent version of the timezone-database. And also all the other awesome things that are part of a new ICU version! Like new translations, new emojis etc.

What did I learn?

Whenever I am using the Intl extension in PHP I will now make sure that the PHP-Version I am using is actually using the latest available ICU-library as one can not take for granted that that is delivered by default.

In essence I should probably check that for every library I use, but most of them do not contain such volatile information as the (constantly changing) timezone DB. And usually fixes for critical issues are ported to the respective libraries by the distros. But that requires me to keep on a distro-version that gets these patches!

So in essence the main thing is – as always – Stay up to date

Debug LDAP via TLS

Yesterday I had to do some debugging to find out why an LDAPS connection didn’t work.

The main trouble was that the authLdap plugin for WordPress didn’t work for someone. After a bit of back and forth we figured out that it worked for other applications but not for PHPs LDAP-extension.

The error they got was the usual cryptic Can't contact LDAP server which says nothing at all as that can mean so many different things.

Continue reading Debug LDAP via TLS