docker-lamp mit eigenen _jorobo_ Projekten

Modify this post

As a reminder, Docker simplifies the management of software in containers. Docker Compose is a tool that simplifies working with multiple containers.

This is about docker-lamp and specifically how special domains are created. docker-lamp is software that provides pre-built images, containers and scripts to help you develop on a web server. In this section I add one of my projects.

Requirements

Besides Docker, Docker Compose is necessary. If you have followed this set so far, everything is fine.

Own projects

I store my projects in the directory /home/youruser/git/joomla-development. The directory is available in the container because I set it that way in the docker-lamp-setup section using docker-compose.override.yml.

Include your own projects

An example project

Wer mein Beispiel nachvollziehen möchte, sollte das Beispielprojekt https://github.com/astridx/boilerplate.git in sein Projektverzeichnis klonen.

$ git clone https://github.com/astridx/boilerplate.git
Klone nach 'boilerplate' ...
...
Löse Unterschiede auf: 100% (6886/6886), fertig.

Anschließend ins Verzeichnis des Beispielprojekts wechseln.

$ cd boilerplate/
Optional: Ein Projekt mit jorobo

Meine Projekte verwendet jorobo. So kann ich Funktionen nutzen, die auf eine Joomla Erweiterung zugeschnitten sind.

Wie man ein Projekt mit jorobo aufsetzt, habe ich in einer Präsentation beschrieben.

jorobo Funktionen
  • vendor/bin/robo build - Baut aus der Erweiterung ein installierbares Joomla Paket oder eine Zip-Datei inklusive Ersetzungen wie das aktuelle Datum oder die Versionsnummer.
  • vendor/bin/robo map - Verlinkt (Symlink) die Erweiterung in eine laufende Joomla Installation
  • vendor/bin/robo headers - Aktualisiert die Copyright-Header aller Dateien des Quellverzeichnises. Dabei wird ein Header eingesetzt, welcher in der jorobo.ini konfigurierbar ist.
  • vendor/bin/robo bump - Tauscht die Zeichenkette __DEPLOY_VERSION__ in jeder Datei im Quellverzeichnis mit der in der jorobo.ini eingestellten Versionsnummer aus.

Um all diese Funktionen nutzen zu können, ist es erforderlich mit Composer PHP-Abhängigkeiten zu installieren.

Mit Composer PHP-Abhängikeiten installieren

Composer steht in den Containern ab PHP-Version 7.3 zur Verfügung. So kann ich mein Projekt, das im Container im Verzeichnis /home/astrid/git/joomla-development/boilerplate eingebunden ist, über den nachfolgendenen Befehl mit allen Abhängigkeiten versorgen.

$ docker exec -it --user 1000 -w /home/astrid/git/joomla-development/boilerplate docker-lamp_php80 composer install

Um in einem Container Composer aufzurufen, muss Git installiert sein: docker exec -it docker-lamp_php80 apk add git.
OCI runtime exec failed: exec failed: container_linux.go:370: starting container process caused: chdir to cwd ("/srv/git/boilerplate") set in config.json failed: no such file or directory: unknown weißt darauf hin, dass man sich im Pfad vertippt hat.

Projekte symlinken

Nachdem alle Abhängigkeiten über Composer installiert wurden, ist es möglich vendor/bin/robo map zu verwenden. dieser Befehl verlinkt meine Joomla Erweiterung automatisch in eine Joomla installation.

Dazu wechsele ich nun wieder in mein Projektverzeichnis.

$ docker exec -it --user 1000 -w /home/astrid/git/joomla-development/boilerplate docker-lamp_php73 ./vendor/bin/robo map /srv/www/joomla/j4dev
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/plugins/webservices/foos","/srv/www/joomla/j4dev/plugins/webservices/foos"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/modules/mod_foo","/srv/www/joomla/j4dev/modules/mod_foo"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/media/com_foos","/srv/www/joomla/j4dev/media/com_foos"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/language/de-DE/pkg_foos.ini","/srv/www/joomla/j4dev/language/de-DE/pkg_foos.ini"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/language/de-DE/pkg_foos.sys.ini","/srv/www/joomla/j4dev/language/de-DE/pkg_foos.sys.ini"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/language/en-GB/pkg_foos.ini","/srv/www/joomla/j4dev/language/en-GB/pkg_foos.ini"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/language/en-GB/pkg_foos.sys.ini","/srv/www/joomla/j4dev/language/en-GB/pkg_foos.sys.ini"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/administrator/components/com_foos","/srv/www/joomla/j4dev/administrator/components/com_foos"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/templates/facile","/srv/www/joomla/j4dev/templates/facile"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/components/com_foos","/srv/www/joomla/j4dev/components/com_foos"]
 [Filesystem\FilesystemStack] symlink ["/home/astrid/git/joomla-development/boilerplate/src/api/components/com_foos","/srv/www/joomla/j4dev/api/components/com_foos"]
Projekte in Joomla entdecken (discovern)

Im Joomla Backend sind die Erweiterungen nun zum Entdecken bereit.

Projekte in Joomla discovern

Modify this post

Comments