Coder Social home page Coder Social logo

4xxi / skeleton Goto Github PK

View Code? Open in Web Editor NEW
54.0 8.0 8.0 31 KB

4xxi Symfony Skeleton is an extension for the official Symfony Skeleton with symfony flex used in 4xxi

Home Page: https://4xxi.com

PHP 44.12% Shell 17.10% Dockerfile 38.78%
symfony symfony3 skeleton-application php7 php symfony4 symfony-skeleton docker-sync

skeleton's Introduction

4xxi Symfony Skeleton

4xxi Symfony Skeleton is an extension for the official Symfony Skeleton (recommended way for starting new projects using Symfony Flex). It's main idea is to keep simplicity of official Skeleton, while adding must-have dependencies and default configs used in 4xxi for developing majority of the projects. It contains bare Symfony Skeleton with the following additions:

  • A minimal set of must-have bundles for production environment
    • ORM Pack (Doctrine + Migrations)
    • FrameworkExtraBundle (Annotations)
    • MonologBundle
    • Sensiolabs SecurityChecker
  • A set of bundles and tools that are necessary for development
  • Docker Compose and Docker Sync configs optimized for development under Linux and MacOS
  • Template for README.md with installation instructions

Creating new project

Creating new project with 4xxi Symfony Skeleton is as easy as running

composer create-project 4xxi/skeleton <project_name> 

where <project_name> is the directory where you want to setup a new project. New project is ready for development immediately after this step.

Additional configurations

Docker

4xxi Symfony Skeleton comes with Docker configuration for local development (includes PHP 7.1, nginx and PostgreSQL) on Linux and MacOS.

  • Follow instructions in docker-sync.yml and docker-compose-sync.yml and update project_name-data-sync volume with the real name of your project. This is needed to keep a unique name for data volume used by Docker Sync for developers working simultaneously on several projects.
  • Optional: Add additional PHP extensions to PHP Docker container by following instructions in config/docker/php/Dockerfile.
  • Optional: Add additinal services (like Redis, RabbitMQ, Elasticsearch) in docker-compose.yml.

Add Bundles and dependencies that are required by our project

Projects created by Flex include only the mininum amount of dependencies by default. Most of additional components that were previously a part of Symfony Standard Edition are not installed, so it is up to you to install them if they are really needed.

Most of components could be installed and auto-configured by Flex by running:

composer req <component>

The list of common Components that may be needed for the project:

  • api
  • asset
  • twig
  • workflow
  • web-link

Update installation instructions

When you are done with previous steps, update Installation Instructions and remove everything above them in this file.

Installation Instructions

Everything below is a template for Installation Instructions. It should be updated with the full steps for setting up your project.

Requirements

Configuration

Application configuration is stored in .env file.

Run cp .env.dist .env to apply the default configuration for local installations.

HTTP port

If you have nginx or apache installed and using 80 port on host system you can either stop them before proceeding or reconfigure Docker to use another port by changing value of EXTERNAL_HTTP_PORT in .env file.

Application environment

You can change application environment to dev of prod by changing APP_ENV variable in .env file.

DB name and credentials

DB name and credentials could by reconfigured by changing variables with POSTGRES prefix in .env file. It is recommended to restart containers after changing these values (new database will be automatically created on containers start).

Installation

1. Start Containers and install dependencies

On Linux:

docker-compose up -d

On MacOS:

docker-sync-stack start

2. Run migrations, install fixtures

docker-compose exec php bin/console doctrine:migrations:migrate

3. Build frontend

Place instructions to build frontend here.

4. Open project

Just go to http://localhost

Application commands

Add application-specific console commands and their description here.

Useful commands and shortcuts

Shortcuts

It is recommended to add short aliases for the following frequently used container commands:

  • docker-compose exec php php to run php in container
  • docker-compose exec php composer to run composer
  • docker-compose exec php bin/console to run Symfony CLI commands
  • docker-compose exec db psql to run PostgreSQL commands

Checking code style and running tests

Fix code style by running PHP CS Fixer:

docker-compose exec php vendor/bin/php-cs-fixer fix

Run PHP Unit Tests:

docker-compose exec php bin/phpunit

skeleton's People

Contributors

artem328 avatar etomilin avatar mickaelandrieu avatar rk4xxi avatar rk4xxicom avatar smirik avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

skeleton's Issues

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.