metabolism / wordpress-bundle
Build enterprise solutions with WordPress
Installs: 3 609
Dependents: 1
Suggesters: 1
Security: 0
Stars: 65
Watchers: 4
Forks: 18
Open Issues: 4
Type:symfony-bundle
Requires
- php: >=8.1
- ext-ctype: *
- ext-curl: *
- ext-fileinfo: *
- ext-gd: *
- ext-iconv: *
- ext-json: *
- ext-mbstring: *
- ext-mysqli: *
- ext-openssl: *
- ext-pcre: *
- ext-session: *
- ext-simplexml: *
- ext-zip: *
- dflydev/dot-access-data: ^3.0
- ifsnop/mysqldump-php: ^2.0
- intervention/image: ^3.4.0
- johnpbloch/wordpress-core: ^5.0|^6.0
- kornrunner/blurhash: ^1.2.2
- metabolism/package-actions: ^1.0
- metabolism/void: ^2.0
- metabolism/wordpress-core-installer: ^1.0
- metabolism/wp-steroids: ^1.3.0
- oscarotero/env: ^2.1
- symfony/asset: ^4.0|^5.0
- symfony/http-client: ^4.0|^5.0
- symfony/templating: ^4.0|^5.0
- symfony/twig-bundle: ^4.0|^5.0
Suggests
- metabolism/acf-extensions: Extensions for ACF
- wpackagist-plugin/advanced-custom-fields: Customise WordPress with powerful, professional and intuitive fields.
- wpackagist-plugin/classic-editor: Restores the previous (« classic ») WordPress editor and the « Edit Post » screen.
- wpackagist-plugin/contact-form-7: Manage multiple contact forms, plus you can customize the form and the mail contents
- wpackagist-plugin/multisite-language-switcher: Add multilingual support using a WordPress multisite
- wpackagist-plugin/query-monitor: Query Monitor is the developer tools panel for WordPress.
- wpackagist-plugin/redirection: Easily manage 301 redirections, keep track of 404 errors
- wpackagist-plugin/relevanssi: Replaces the standard WordPress search with a better search engine, with lots of features and configurable options.
- wpackagist-plugin/wordpress-seo: The favorite WordPress SEO plugin of millions of users worldwide!
- wpackagist-plugin/wp-2fa: Harden your website login page; add two-factor authentication (2FA) for all your users with this easy to use plugin.
- wpackagist-plugin/wp-smartcrop: Set the 'focal point' of any image, right from the media library
- 2.3.x-dev
- 2.3.7
- 2.3.6
- 2.3.5
- 2.3.4
- 2.3.3
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.x-dev
- 2.2.7
- 2.2.6
- 2.2.5
- 2.2.4
- 2.2.3
- 2.2.2
- 2.2.1
- 2.2.0
- 2.1.x-dev
- 2.1.7
- 2.1.6
- 2.1.5
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.x-dev
- 2.0.2
- 2.0.1
- 2.0.0
- 1.4.x-dev
- 1.4.16
- 1.4.15
- 1.4.14
- 1.4.13
- 1.4.12
- 1.4.11
- 1.4.10
- 1.4.9
- 1.4.8
- 1.4.7
- 1.4.6
- 1.4.5
- 1.4.4
- 1.4.3
- 1.4.2
- 1.4.1
- 1.4.0
- 1.3.11
- 1.3.10
- 1.3.9
- 1.3.8
- 1.3.7
- 1.3.6
- 1.3.5
- 1.3.4
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.5
- 1.2.4
- 1.2.3
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.0
- 1.0.7
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-tests
This package is auto-updated.
Last update: 2024-12-29 09:39:45 UTC
README
Build enterprise solutions with WordPress.
The Symfony WordPress Backoffice Bundle is a powerful library that seamlessly combines the flexibility of Symfony, a robust PHP framework, with the user-friendliness of WordPress, a popular content management system (CMS).
This bundle enables you to harness Symfony's structure to develop highly customized web applications while using WordPress as the backend for content management. It simplifies the integration of WordPress into your Symfony project, allowing you to leverage the best of both worlds.
How does it work ?
When the WordPress bundle is loaded, it selectively includes the essential WordPress Core files required for utilizing WordPress functions and plugins within Symfony.
Example :
// src/Controller/BlogController.php /** * @param Post $post * @param PostRepository $postRepository * @return Response */ public function pageAction(Post $post, PostRepository $postRepository) { $context = []; // get current post $context['post'] = $post; // find 10 "guide" ordered by title $context['guides'] = $postRepository->findBy(['post_type'=>'guide'], ['title'=>'ASC'], 10); return $this->render('page.html.twig', $context); }
{# templates/page.html.twig #} {% extends 'layout.html.twig' %} {% block body %} <article id="post-{{ post.ID }}" class="entry {{ post.class }}"> {% if post.thumbnail %} <img src="{{ post.thumbnail|resize(800, 600) }}" alt="{{ post.thumbnail.alt }}"/> {% endif %} <div class="entry-content"> {{ post.content|raw }} {# or #} {% for block in post.blocks %} {% include 'block/'~block.name~'.html.twig' %} {% endfor %} </div> <small>{{ post.custom_fields.mention }}</small> {% for guide in guides %} {% include 'guide.html.twig' with {props:guide} %} {% endfor %} </article> {% endblock body %}
Documentation
- WordPress Bundle Documentation
- WP Steroids WordPress plugin
- Installation / Getting started
- Twig Cookbook
Changelog
Please see Changelog for more information on what has changed recently.
Features
Using Composer :
- Install/update WordPress via composer
- Install/update plugins via composer
Using Symfony :
- Twig template engine
- Folder structure
- Http Cache
- Routing
- YML configuration
- DotEnv
- Enhanced Security ( WordPress is 'hidden' )
- Dynamic image resize
- MVC
Using WordPress Bundle :
- Post/Term/User Repository
- Controller argument resolver for post(s), term, user and blog
- Symfony Cache invalidation on update ( Varnish compatible )
- Post/PostCollection/Image/Menu/Term/User/Comment/Blog/Block entity
- Possible use of WordPress predefined routes
- Site health checker url
Using WP Steroids WordPress plugin :
- WordPress' configuration using yml ( view sample )
- Permalink configuration for custom post type and taxonomy
- Maintenance mode
- Backup download in dev mode
- Build hook
- Disabled automatic update
- Enhanced Security
- Better guid using RFC 4122 compliant UUID version 5
- Multisite images sync ( for multisite as multilangue )
- SVG Support
- Better Performance
- WordPress Bugfix
- CSS Fix
- Multisite post deep copy ( with multisite-language-switcher plugin )
- Custom datatable support with view and delete actions in admin
- Google translate or Deepl integration
- Optimisations
YML file allows to configure :
- Image options
- Maintenance support
- Admin pages removal
- WYSIWYG MCE Editor
- Feature Support
- Multi-site configuration
- ACF/Carbon Fields configuration
- Menu
- Custom Post type
- Custom Taxonomy
- Block
- Page, post, taxonomy template
- Page state
- Post format
- External table viewer
- Advanced roles
Installation
Make sure Composer is installed globally, as explained in the installation chapter of the Composer documentation.
Creating a new project
$ composer create-project metabolism/wordpress-skeleton my_project_directory
Please read the full bundle installation guide to continue
Setting up an existing Symfony project
Define installation path for WordPress core and plugins in composer.json
"extra": { "installer-paths": { "public/wp-bundle/mu-plugins/{$name}/": ["type:wordpress-muplugin"], "public/wp-bundle/plugins/{$name}/": ["type:wordpress-plugin"], "public/wp-bundle/themes/{$name}/": ["type:wordpress-theme"], "public/edition/": ["type:wordpress-core"] } }
Install the bundle
$ composer require metabolism/wordpress-bundle
For applications that don't use Symfony Flex
Register the bundle
// config/bundles.php return [ // ... Metabolism\WordPressBundle\WordPressBundle::class => ['all' => true], ];
Please read the full bundle installation guide to continue
Demo
https://github.com/metabolism/wordpress-bundle-demo
This is an implementation of the Twenty Nineteen WordPress theme for wordpress-bundle.
Recommended / tested plugins
- Advanced custom fields Customise WordPress with powerful, professional and intuitive fields.
- ACF extensions Extensions for ACF
- Classic editor Restores the previous (« classic ») WordPress editor and the « Edit Post » screen.
- WP smartcrop Set the 'focal point' of any image, right from the media library
- Multisite language switcher Add multilingual support using a WordPress multisite
- WordPress seo The favorite WordPress SEO plugin of millions of users worldwide!
- Query monitor Query Monitor is the developer tools panel for WordPress
- Redirection Easily manage 301 redirections, keep track of 404 errors
- Contact form 7 Manage multiple contact forms, plus you can customize the form and the mail contents
Roadmap
- More samples
- Global maintenance mode for multi-site
- Unit tests
- Better type hinting
Drawbacks
WordPress' functions are available in the global namespace.
Some WordPress plugins may not work ( ex : Woocommerce ) or require extra works.
Treeware
This package is Treeware. If you use it in production, then we ask that you buy the world a tree to thank us for our work. By contributing to the Treeware forest you’ll be creating employment for local families and restoring wildlife habitats.
License
The MIT License (MIT). Please see License File for more information.