Skip to content

Commit

Permalink
Chore(web-twig): Setup minimul Symfony app for local webserver
Browse files Browse the repository at this point in the history
  • Loading branch information
literat committed Mar 22, 2023
1 parent ccfc64a commit 533d386
Show file tree
Hide file tree
Showing 20 changed files with 349 additions and 5 deletions.
20 changes: 20 additions & 0 deletions packages/web-twig/.env
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# In all environments, the following files are loaded if they exist,
# the latter taking precedence over the former:
#
# * .env contains default values for the environment variables needed by the app
# * .env.local uncommitted file with local overrides
# * .env.$APP_ENV committed environment-specific defaults
# * .env.$APP_ENV.local uncommitted environment-specific overrides
#
# Real environment variables win over .env files.
#
# DO NOT DEFINE PRODUCTION SECRETS IN THIS FILE NOR IN ANY OTHER COMMITTED FILES.
# https://symfony.com/doc/current/configuration/secrets.html
#
# Run "composer dump-env prod" to compile .env files for production use (requires symfony/flex >=1.2).
# https://symfony.com/doc/current/best_practices.html#use-environment-variables-for-infrastructure-configuration

###> symfony/framework-bundle ###
APP_ENV=dev
APP_SECRET=c5a36b2e4bbb9647355581c5666c5a18
###< symfony/framework-bundle ###
6 changes: 6 additions & 0 deletions packages/web-twig/.env.test
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# define your env variables for the test env here
KERNEL_CLASS='App\Kernel'
APP_SECRET='$ecretf0rt3st'
SYMFONY_DEPRECATIONS_HELPER=999999
PANTHER_APP_ENV=panther
PANTHER_ERROR_SCREENSHOT_DIR=./var/error-screenshots
20 changes: 20 additions & 0 deletions packages/web-twig/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,23 @@ vendor/
composer.lock
.phpunit.result.cache
coverage/

###> symfony/framework-bundle ###
/.env.local
/.env.local.php
/.env.*.local
/config/secrets/prod/prod.decrypt.private.php
/public/bundles/
/var/
/vendor/
###< symfony/framework-bundle ###

###> friendsofphp/php-cs-fixer ###
/.php-cs-fixer.php
/.php-cs-fixer.cache
###< friendsofphp/php-cs-fixer ###

###> phpunit/phpunit ###
/phpunit.xml
.phpunit.result.cache
###< phpunit/phpunit ###
Empty file.
11 changes: 11 additions & 0 deletions packages/web-twig/app/Kernel.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
<?php

namespace App;

use Symfony\Bundle\FrameworkBundle\Kernel\MicroKernelTrait;
use Symfony\Component\HttpKernel\Kernel as BaseKernel;

class Kernel extends BaseKernel
{
use MicroKernelTrait;
}
17 changes: 17 additions & 0 deletions packages/web-twig/bin/console
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
#!/usr/bin/env php
<?php

use App\Kernel;
use Symfony\Bundle\FrameworkBundle\Console\Application;

if (!is_file(dirname(__DIR__).'/vendor/autoload_runtime.php')) {
throw new LogicException('Symfony Runtime is missing. Try running "composer require symfony/runtime".');
}

require_once dirname(__DIR__).'/vendor/autoload_runtime.php';

return function (array $context) {
$kernel = new Kernel($context['APP_ENV'], (bool) $context['APP_DEBUG']);

return new Application($kernel);
};
39 changes: 35 additions & 4 deletions packages/web-twig/composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,8 @@
},
"autoload-dev": {
"psr-4": {
"Lmc\\SpiritWebTwigBundle\\": "tests/"
"Lmc\\SpiritWebTwigBundle\\": "tests/",
"App\\": "app/"
}
},
"require": {
Expand All @@ -34,12 +35,20 @@
"phpunit/phpunit": "^9",
"mockery/mockery": "^1.5",
"lmc/coding-standard": "^3.2",
"symfony/yaml": "^4.4 || ^5.4 || ^6.1",
"symfony/yaml": "^5.4",
"phpstan/phpstan": "^1.2",
"phpstan/phpstan-mockery": "^1.0",
"phpstan/extension-installer": "^1.1",
"phpstan/phpstan-symfony": "^1.0",
"spatie/phpunit-snapshot-assertions": "^4.2.12"
"spatie/phpunit-snapshot-assertions": "^4.2.12",
"symfony/console": "^5.4",
"symfony/dotenv": "^5.4",
"symfony/flex": "^1.19",
"symfony/framework-bundle": "^5.4",
"symfony/runtime": "^5.4",
"symfony/twig-bridge": "5.4.21",
"symfony/twig-bundle": "5.4.21",
"twig/extra-bundle": "^3.5"
},
"scripts": {
"ecs": "vendor/bin/ecs check --no-progress-bar --ansi src/ tests/",
Expand All @@ -52,12 +61,34 @@
"@ecs",
"@phpunit",
"@phpstan"
],
"auto-scripts": {
"cache:clear": "symfony-cmd",
"assets:install %PUBLIC_DIR%": "symfony-cmd"
},
"post-install-cmd": [
"@auto-scripts"
],
"post-update-cmd": [
"@auto-scripts"
]
},
"conflict": {
"symfony/symfony": "*"
},
"extra": {
"symfony": {
"allow-contrib": false,
"require": "6.2.*"
}
},
"config": {
"allow-plugins": {
"dealerdirect/phpcodesniffer-composer-installer": true,
"phpstan/extension-installer": true
"phpstan/extension-installer": true,
"php-http/discovery": true,
"symfony/flex": true,
"symfony/runtime": true
}
}
}
8 changes: 8 additions & 0 deletions packages/web-twig/config/bundles.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
<?php

return [
Lmc\TwigXBundle\TwigXBundle::class => ['all' => true],
Symfony\Bundle\FrameworkBundle\FrameworkBundle::class => ['all' => true],
Symfony\Bundle\TwigBundle\TwigBundle::class => ['all' => true],
Twig\Extra\TwigExtraBundle\TwigExtraBundle::class => ['all' => true],
];
19 changes: 19 additions & 0 deletions packages/web-twig/config/packages/cache.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
framework:
cache:
# Unique name of your app: used to compute stable namespaces for cache keys.
#prefix_seed: your_vendor_name/app_name

# The "app" cache stores to the filesystem by default.
# The data in this cache should persist between deploys.
# Other options include:

# Redis
#app: cache.adapter.redis
#default_redis_provider: redis://localhost

# APCu (not recommended with heavy random-write workloads as memory fragmentation can cause perf issues)
#app: cache.adapter.apcu

# Namespaced pools use the above "app" backend by default
#pools:
#my.dedicated.cache: null
24 changes: 24 additions & 0 deletions packages/web-twig/config/packages/framework.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# see https://symfony.com/doc/current/reference/configuration/framework.html
framework:
secret: '%env(APP_SECRET)%'
#csrf_protection: true
http_method_override: false

# Enables session support. Note that the session will ONLY be started if you read or write from it.
# Remove or comment this section to explicitly disable session support.
session:
handler_id: null
cookie_secure: auto
cookie_samesite: lax
storage_factory_id: session.storage.factory.native

#esi: true
#fragments: true
php_errors:
log: true

when@test:
framework:
test: true
session:
storage_factory_id: session.storage.factory.mock_file
12 changes: 12 additions & 0 deletions packages/web-twig/config/packages/routing.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
framework:
router:
utf8: true

# Configure how to generate URLs in non-HTTP contexts, such as CLI commands.
# See https://symfony.com/doc/current/routing.html#generating-urls-in-commands
#default_uri: http://localhost

when@prod:
framework:
router:
strict_requirements: null
6 changes: 6 additions & 0 deletions packages/web-twig/config/packages/twig.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
twig:
default_path: '%kernel.project_dir%/templates'

when@test:
twig:
strict_variables: true
5 changes: 5 additions & 0 deletions packages/web-twig/config/preload.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
<?php

if (file_exists(dirname(__DIR__).'/var/cache/prod/App_KernelProdContainer.preload.php')) {
require dirname(__DIR__).'/var/cache/prod/App_KernelProdContainer.preload.php';
}
3 changes: 3 additions & 0 deletions packages/web-twig/config/routes.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
#index:
# path: /
# controller: App\Controller\DefaultController::index
4 changes: 4 additions & 0 deletions packages/web-twig/config/routes/framework.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
when@dev:
_errors:
resource: '@FrameworkBundle/Resources/config/routing/errors.xml'
prefix: /_error
24 changes: 24 additions & 0 deletions packages/web-twig/config/services.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# This file is the entry point to configure your own services.
# Files in the packages/ subdirectory configure your dependencies.

# Put parameters here that don't need to change on each machine where the app is deployed
# https://symfony.com/doc/current/best_practices.html#use-parameters-for-application-configuration
parameters:

services:
# default configuration for services in *this* file
_defaults:
autowire: true # Automatically injects dependencies in your services.
autoconfigure: true # Automatically registers your services as commands, event subscribers, etc.

# makes classes in src/ available to be used as services
# this creates a service per class whose id is the fully-qualified class name
App\:
resource: '../app/'
exclude:
- '../app/DependencyInjection/'
- '../app/Entity/'
- '../app/Kernel.php'

# add more service definitions when explicit configuration is needed
# please note that last definitions always *replace* previous ones
5 changes: 5 additions & 0 deletions packages/web-twig/phpunit.xml.dist
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,11 @@
<php>
<!-- E_ALL = 30719 -->
<ini name="error_reporting" value="30719"/>

<!-- ###+ symfony/framework-bundle ### -->
<env name="APP_ENV" value="dev"/>
<env name="APP_SECRET" value="678653c8d31be63221cddd61278f16db"/>
<!-- ###- symfony/framework-bundle ### -->
</php>
<testsuites>
<testsuite name="Bundle Test Suite">
Expand Down
1 change: 0 additions & 1 deletion packages/web-twig/public/.gitignore

This file was deleted.

9 changes: 9 additions & 0 deletions packages/web-twig/public/index.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
<?php

use App\Kernel;

require_once dirname(__DIR__).'/vendor/autoload_runtime.php';

return function (array $context) {
return new Kernel($context['APP_ENV'], (bool) $context['APP_DEBUG']);
};
Loading

0 comments on commit 533d386

Please sign in to comment.