1
0
Fork 0
mirror of https://github.com/archtechx/tenancy.git synced 2025-12-12 13:54:03 +00:00

PHP 8 support (#542)

* PHP 8 support, test workflow syntax

* Try using a custom data structure in the workflow

* Try using matrix include

* Default PHP target

* single include

* fix composer package name

* [WIP] Try using dev-master for valuestore

* Update spatie/valuestore constraint to be stable
This commit is contained in:
Samuel Štancl 2020-11-30 17:30:42 +01:00 committed by GitHub
parent 126afcd0dd
commit 30a1f9102d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 40 additions and 35 deletions

View file

@ -15,16 +15,18 @@ jobs:
strategy: strategy:
matrix: matrix:
laravel: [ php_version: ["7.4"]
"^6.0", php_target: ["php:7.4-cli"]
"^7.0", laravel: ["^6.0", "^8.0"]
"^8.0" include:
] - php_version: "8.0"
php_target: "php:8.0.0RC5-cli"
laravel: "^8.0"
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
- name: Start docker containers - name: Start docker containers
run: docker-compose up -d run: PHP_TARGET=${{ matrix.php_target }} PHP_VERSION=${{ matrix.php_version }} docker-compose up -d
- name: Install dependencies - name: Install dependencies
run: docker-compose exec -T test composer require --no-interaction "laravel/framework:${{ matrix.laravel }}" run: docker-compose exec -T test composer require --no-interaction "laravel/framework:${{ matrix.laravel }}"
- name: Run tests - name: Run tests

View file

@ -1,9 +1,8 @@
ARG PHP_TARGET=7.4 ARG PHP_VERSION=7.4
ARG PHP_TARGET=php:${PHP_VERSION}-cli
FROM php:${PHP_TARGET}-cli FROM ${PHP_TARGET}
# We need to do this again as the FROM line seems to clear the ARG
ARG PHP_TARGET=7.4
ARG COMPOSER_TARGET=2.0.3 ARG COMPOSER_TARGET=2.0.3
WORKDIR /var/www/html WORKDIR /var/www/html
@ -11,8 +10,8 @@ WORKDIR /var/www/html
LABEL org.opencontainers.image.source=https://github.com/stancl/tenancy \ LABEL org.opencontainers.image.source=https://github.com/stancl/tenancy \
org.opencontainers.image.vendor="Samuel Štancl" \ org.opencontainers.image.vendor="Samuel Štancl" \
org.opencontainers.image.licenses="MIT" \ org.opencontainers.image.licenses="MIT" \
org.opencontainers.image.title="PHP ${PHP_TARGET} with modules for laravel support" \ org.opencontainers.image.title="PHP ${PHP_VERSION} with modules for laravel support" \
org.opencontainers.image.description="PHP ${PHP_TARGET} with a set of php/os packages suitable for running Laravel apps" org.opencontainers.image.description="PHP ${PHP_VERSION} with a set of php/os packages suitable for running Laravel apps"
# our default timezone and langauge # our default timezone and langauge
ENV TZ=Europe/London ENV TZ=Europe/London
@ -23,28 +22,29 @@ ENV LANG=en_GB.UTF-8
# Dockerfile _and pin the versions_! Eg: # Dockerfile _and pin the versions_! Eg:
# RUN pecl install memcached-2.2.0 && docker-php-ext-enable memcached # RUN pecl install memcached-2.2.0 && docker-php-ext-enable memcached
RUN apt-get update \ # install some OS packages we need
# install some OS packages we need RUN apt-get update
&& apt-get install -y --no-install-recommends libfreetype6-dev libjpeg62-turbo-dev libpng-dev libgmp-dev libldap2-dev netcat curl sqlite3 libsqlite3-dev libpq-dev libzip-dev unzip vim-tiny gosu git \ RUN apt-get install -y --no-install-recommends libfreetype6-dev libjpeg62-turbo-dev libpng-dev libgmp-dev libldap2-dev netcat curl sqlite3 libsqlite3-dev libpq-dev libzip-dev unzip vim-tiny gosu git
# install php extensions # install php extensions
&& if [ "${PHP_TARGET}" = "7.4" ]; then docker-php-ext-configure gd --with-freetype --with-jpeg; else docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/; fi \ RUN docker-php-ext-configure pgsql -with-pgsql=/usr/local/pgsql \
&& docker-php-ext-configure pgsql -with-pgsql=/usr/local/pgsql \ # && if [ "${PHP_VERSION}" = "7.4" ]; then docker-php-ext-configure gd --with-freetype --with-jpeg; else docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/; fi \
&& docker-php-ext-install -j$(nproc) gd pdo pdo_mysql pdo_pgsql pdo_sqlite pgsql zip gmp bcmath pcntl ldap sysvmsg exif \ && docker-php-ext-install -j$(nproc) gd pdo pdo_mysql pdo_pgsql pdo_sqlite pgsql zip gmp bcmath pcntl ldap sysvmsg exif \
# install the redis php extension # install the redis php extension
&& pecl install redis-5.0.2 \ && pecl install redis-5.3.2 \
&& docker-php-ext-enable redis \ && docker-php-ext-enable redis \
# install the pcov extention # install the pcov extention
&& pecl install pcov \ && pecl install pcov \
&& docker-php-ext-enable pcov \ && docker-php-ext-enable pcov \
&& echo "pcov.enabled = 1" > /usr/local/etc/php/conf.d/pcov.ini \ && echo "pcov.enabled = 1" > /usr/local/etc/php/conf.d/pcov.ini
# clear the apt cache # clear the apt cache
RUN rm -rf /var/lib/apt/lists/* \
&& rm -rf /var/lib/apt/lists/* \ && rm -rf /var/lib/apt/lists/* \
# install composer # install composer
&& curl -o /tmp/composer-setup.php https://getcomposer.org/installer \ && curl -o /tmp/composer-setup.php https://getcomposer.org/installer \
&& curl -o /tmp/composer-setup.sig https://composer.github.io/installer.sig \ && curl -o /tmp/composer-setup.sig https://composer.github.io/installer.sig \
&& php -r "if (hash('SHA384', file_get_contents('/tmp/composer-setup.php')) !== trim(file_get_contents('/tmp/composer-setup.sig'))) { unlink('/tmp/composer-setup.php'); echo 'Invalid installer' . PHP_EOL; exit(1); }" \ && php -r "if (hash('SHA384', file_get_contents('/tmp/composer-setup.php')) !== trim(file_get_contents('/tmp/composer-setup.sig'))) { unlink('/tmp/composer-setup.php'); echo 'Invalid installer' . PHP_EOL; exit(1); }" \
&& php /tmp/composer-setup.php --version=${COMPOSER_TARGET} --no-ansi --install-dir=/usr/local/bin --filename=composer --snapshot \ && php /tmp/composer-setup.php --version=${COMPOSER_TARGET} --no-ansi --install-dir=/usr/local/bin --filename=composer --snapshot \
&& rm -f /tmp/composer-setup.* \ && rm -f /tmp/composer-setup.*
# set the system timezone # set the system timezone
&& ln -snf /usr/share/zoneinfo/$TZ /etc/localtime \ RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime \
&& echo $TZ > /etc/timezone && echo $TZ > /etc/timezone

View file

@ -1,5 +1,5 @@
{ {
"name": "stancl/tenancy-private", "name": "stancl/tenancy",
"description": "Automatic multi-tenancy for your Laravel application.", "description": "Automatic multi-tenancy for your Laravel application.",
"keywords": ["laravel", "multi-tenancy", "multi-database", "tenancy"], "keywords": ["laravel", "multi-tenancy", "multi-database", "tenancy"],
"license": "MIT", "license": "MIT",
@ -23,7 +23,7 @@
"orchestra/testbench-browser-kit": "^4.0|^5.0|^6.0", "orchestra/testbench-browser-kit": "^4.0|^5.0|^6.0",
"league/flysystem-aws-s3-v3": "~1.0", "league/flysystem-aws-s3-v3": "~1.0",
"doctrine/dbal": "^2.10", "doctrine/dbal": "^2.10",
"spatie/valuestore": "^1.2" "spatie/valuestore": "^1.2.5"
}, },
"autoload": { "autoload": {
"psr-4": { "psr-4": {

View file

@ -3,6 +3,9 @@ services:
test: test:
build: build:
context: . context: .
args:
PHP_VERSION: ${PHP_VERSION}
PHP_TARGET: ${PHP_TARGET}
depends_on: depends_on:
mysql: mysql:
condition: service_healthy condition: service_healthy

View file

@ -59,7 +59,11 @@ class FilesystemTenancyBootstrapper implements TenancyBootstrapper
$filesystemDisk = Storage::disk($disk); $filesystemDisk = Storage::disk($disk);
$this->originalPaths['disks'][$disk] = $filesystemDisk->getAdapter()->getPathPrefix(); $this->originalPaths['disks'][$disk] = $filesystemDisk->getAdapter()->getPathPrefix();
if ($root = str_replace('%storage_path%', storage_path(), $this->app['config']["tenancy.filesystem.root_override.{$disk}"])) { if ($root = str_replace(
'%storage_path%',
storage_path(),
$this->app['config']["tenancy.filesystem.root_override.{$disk}"] ?? ''
)) {
$filesystemDisk->getAdapter()->setPathPrefix($finalPrefix = $root); $filesystemDisk->getAdapter()->setPathPrefix($finalPrefix = $root);
} else { } else {
$root = $this->app['config']["filesystems.disks.{$disk}.root"]; $root = $this->app['config']["filesystems.disks.{$disk}.root"];

View file

@ -10,19 +10,15 @@ trait CreatesDatabaseUsers
{ {
public function createDatabase(TenantWithDatabase $tenant): bool public function createDatabase(TenantWithDatabase $tenant): bool
{ {
return $this->database()->transaction(function () use ($tenant) { parent::createDatabase($tenant);
parent::createDatabase($tenant);
return $this->createUser($tenant->database()); return $this->createUser($tenant->database());
});
} }
public function deleteDatabase(TenantWithDatabase $tenant): bool public function deleteDatabase(TenantWithDatabase $tenant): bool
{ {
return $this->database()->transaction(function () use ($tenant) { parent::deleteDatabase($tenant);
parent::deleteDatabase($tenant);
return $this->deleteUser($tenant->database()); return $this->deleteUser($tenant->database());
});
} }
} }