diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 00000000..1cf15ae2 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,10 @@ +.dockerignore +.gitignore +*.md +.git/ +.idea/ +.DS_Store/ +docker-compose.* +LICENSE +nginx.conf +yarn.lock diff --git a/.env.example b/.env.example index 19e36d8c..e8c6a0c8 100644 --- a/.env.example +++ b/.env.example @@ -5,11 +5,11 @@ APP_LOG_LEVEL=debug APP_URL=http://crater.test DB_CONNECTION=mysql -DB_HOST=127.0.0.1 +DB_HOST=db DB_PORT=3306 DB_DATABASE=crater -DB_USERNAME=root -DB_PASSWORD=bytefury +DB_USERNAME=crater +DB_PASSWORD=crater BROADCAST_DRIVER=log CACHE_DRIVER=file diff --git a/.gitignore b/.gitignore index 0afb940b..5f355185 100644 --- a/.gitignore +++ b/.gitignore @@ -11,3 +11,5 @@ Homestead.yaml .rnd /.expo /.vscode +docker-compose.yml +docker-compose.yaml diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 00000000..c3fa5a83 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,52 @@ +##### STAGE 1 ##### + +FROM composer as composer + +# Copy composer files from project root into composer container's working dir +COPY composer.* /app/ + +# Copy database directory for autoloader optimization +COPY database /app/database + +# Run composer to build dependencies in vendor folder +RUN composer install --no-scripts --no-suggest --no-interaction --prefer-dist --optimize-autoloader + +# Copy everything from project root into composer container's working dir +COPY . /app + +RUN composer dump-autoload --optimize --classmap-authoritative + +##### STAGE 2 ##### + +FROM php:7.3.12-fpm-alpine + +# Use the default production configuration +RUN mv "$PHP_INI_DIR/php.ini-production" "$PHP_INI_DIR/php.ini" + +RUN apk add --no-cache libpng-dev libxml2-dev oniguruma-dev && \ + docker-php-ext-install bcmath ctype json gd mbstring pdo pdo_mysql tokenizer xml + +# Set container's working dir +WORKDIR /app + +# Copy everything from project root into php container's working dir +COPY . /app + +# Copy vendor folder from composer container into php container +COPY --from=composer /app/vendor /app/vendor + +RUN touch database/database.sqlite && \ + cp .env.example .env && \ + php artisan config:cache && \ + php artisan passport:keys && \ + php artisan key:generate && \ + chown -R www-data:www-data . && \ + chmod -R 755 . && \ + chmod -R 775 storage/framework/ && \ + chmod -R 775 storage/logs/ && \ + chmod -R 775 bootstrap/cache/ + +EXPOSE 9000 + +CMD ["php-fpm", "--nodaemonize"] + diff --git a/config/app.php b/config/app.php index 0d4c2fc4..245b5c38 100644 --- a/config/app.php +++ b/config/app.php @@ -1,4 +1,4 @@ - 'LocationController@getCountries' ]); -Route::get('/states/{id}', [ - 'as' => 'states', - 'uses' => 'LocationController@getStates' -]); - -Route::get('/cities/{id}', [ - 'as' => 'cities', - 'uses' => 'LocationController@getCities' -]); - // Onboarding //----------------------------------