The new year is now a few days old and I'd like to take to opportunity to look back at what happened in my opsi world in 2018.
The year begun with getting opsi 4.1 ready for release.
Most of the development work was already done but for a proper release you need some more.
Documentation is one of the things.
Not only did we need to change the documentation in some places, we also worked hard on making a reliable and easy to follow migration guide.
The migration guide is quite large, covering many distributions and mentioning all kind of changes that could be done, but the things you need to do come done to a few steps.
The release has also led to writing some tools that are in use at our public repositories.
Behind the scenes we have tools that help us making the release of new opsi packages an easier task by automatically collecting the corresponding files and knowing where the files need to be placed (localboot/netboot; linux, windows or both).
Since a lot of the packages are runnable under opsi 4.0 and opsi 4.1 we wanted to have these packages available in both repositories.
We solve this by having a tool watching the opsi 4.0 repository directories and once there is a new file this will be linked to the corresponding repository for opsi 4.1.
This is accompied by another tool that watches all our repositories and alters the access rights of new files so that retrieving won't fail because of insufficent rights.
This is one of the simpler and still nicer things I'd like to integrate into opsi in the future because it removes a potential error source when handling packages.
From my view the release of opsi 4.1 went nicely.
Problems seemed to be rare and seemed to come mostly from diverging from the migration steps.
The order was important this time because we changed the way we are tracking what migrations have been run.
This will save us some headaches in the future since we know what migrations have been run and therefore what migrations are missing.
I enjoy that we are able to rely on systemd and Python 2.7 with opsi 4.1.
This makes a lot of things easier for developing and maintaining things.
The release of opsi 4.1 happened shortly before the great opsiconf.
The conference itself was a great joy to me.
I got to see new and old faces and talk to many people - and I've talked to even more if time would have allowed it!
One thing that I'd like to improve with the next conference is the diversity.
I think this is something where we really could do better but I'm unsure of how to achieve it.
I know that we have a very diverse user base and I'd love this to be represented a lot more at the next conference!
With release and conference behind me it was again time to look towards the future.
One of the major points we started working to is the migration to Python 3.
Since I've been constantly blogging about this topic I won't go into detail here.
Being able to focus on this wouldn't have been possible if there weren't my co-workers giving the time and taking care of other tasks I'd normally do.
I'm very thankful for this because this allowed for making good progress.
Lately some more things have come up that I personally had to take care of and this has shown me even more how valuable the time has been.
Another big change was the overhaul of data collection for opsipxeconfd.
It took us quite some time to get to this solution but I am happy how this turned out.
The duration it took to get there is one thing not bringing a smile to my face but if you are stepping into a new terrain you won't always know what waits for you there.
In between all this there has been the occasional bugfix that lead to touching opi 4.0.
This is where the migration from subversion to git really payed off.
Maintaining multiple versions and bringing changes from one into the other has become mostly a no-brainer.
Because we are already working on a new larger release for opsi this means that most repositories are having at least three different version branches at the same time.
Before we went all in on git we tried some workflows and finally came up with our one which has been heavily inspired by git flow.
The winter of 2018 has seen some work on the monitoring extension I quite enjoyed because there was a constant stream of feedback and even though most changes were rather small I had the feeling that these changes made a rather large improvement.
And then things slowed down before the year came to an end.
And so did the support span for opsi 4.0.
New things are waiting for us in 2019, new things will be coming in 2019.
I am looking forward to this and hope you do aswell!