teknoo / east-website
Universal package, following the #East programming philosophy, build on Teknoo/East-Foundation (and Teknoo/Recipe), and implementing a basic CMS to display dynamics pages with different types and templates.
Fund package maintenance!
Patreon
TeknooSoftware
Installs: 5 167
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: ^8.2
- ext-json: *
- php-di/php-di: ^7.0.7
- teknoo/east-common: ^3
- teknoo/east-foundation: ^8
- teknoo/east-translation: ^1
- teknoo/immutable: ^3.0.18
- teknoo/recipe: ^6
- teknoo/states: ^6.4.1
Requires (Dev)
- ext-mongodb: *
- ext-simplexml: *
- behat/behat: ^3.15
- doctrine/common: ^3.4.5
- doctrine/mongodb-odm: ^2.9
- doctrine/mongodb-odm-bundle: ^4.7||^5
- doctrine/persistence: ^3.4||^4
- knpuniversity/oauth2-client-bundle: ^2.18
- laminas/laminas-diactoros: ^3.3
- league/oauth2-client: ^2.7
- league/uri: ^7.4
- nikic/php-parser: ^4.18||^5.3.1
- phpstan/extension-installer: ^1.4.3
- phpstan/phpstan: ^1.12.7
- phpunit/phpunit: ^11.4
- psr/cache: ^3
- roave/security-advisories: dev-latest
- squizlabs/php_codesniffer: ^3.10.3
- symfony/config: ^6.3||^7
- symfony/console: ^6.3||^7
- symfony/dependency-injection: ^6.3||^7
- symfony/error-handler: ^6.3||^7
- symfony/finder: ^6.3||^7
- symfony/form: ^6.3||^7
- symfony/html-sanitizer: ^6.3||^7
- symfony/http-kernel: ^6.3||^7
- symfony/options-resolver: ^6.3||^7
- symfony/password-hasher: ^6.3||^7
- symfony/property-access: ^6.3||^7
- symfony/psr-http-message-bridge: ^2.3.1||^6.4||^7
- symfony/routing: ^6.3||^7
- symfony/security-bundle: ^6.3||^7
- symfony/security-core: ^6.3||^7
- symfony/security-http: ^6.3||^7
- symfony/translation: ^6.3||^7
- symfony/var-dumper: ^6.3||^7
- symfony/var-exporter: ^6.3||^7
- symfony/yaml: ^6.3||^7
- teknoo/bridge-phpdi-symfony: ^6.1
- twig/twig: ^3.8
Conflicts
- doctrine/persistence: <3.0
- dev-master
- 10.0.3
- 10.0.2
- 10.0.1
- 10.0.0
- 9.2.5
- 9.2.4
- 9.2.3
- 9.2.2
- 9.2.1
- 9.2.0
- 9.1.12
- 9.1.11
- 9.1.10
- 9.1.9
- 9.1.8
- 9.1.7
- 9.1.6
- 9.1.5
- 9.1.4
- 9.1.3
- 9.1.2
- 9.1.1
- 9.1.0
- 9.0.3
- 9.0.2
- 9.0.1
- 9.0.0
- 8.6.5
- 8.6.4
- 8.6.3
- 8.6.2
- 8.6.1
- 8.6.0
- 8.5.1
- 8.5.0
- 8.4.3
- 8.4.2
- 8.4.1
- 8.4.0
- 8.3.6
- 8.3.5
- 8.3.4
- 8.3.3
- 8.3.2
- 8.3.1
- 8.3.0
- 8.2.0
- 8.1.1
- 8.1.0
- 8.0.7
- 8.0.6
- 8.0.5
- 8.0.4
- 8.0.3
- 8.0.2
- 8.0.1
- 8.0.0
- 8.0.0-beta1
- 7.0.3
- 7.0.2
- 7.0.1
- 7.0.0
- 7.0.0-beta5
- 7.0.0-beta4
- 7.0.0-beta3
- 7.0.0-beta2
- 7.0.0-beta1
- 6.1.10
- 6.1.9
- 6.1.7
- 6.1.6
- 6.1.5
- 6.1.4
- 6.1.3
- 6.1.1
- 6.1.0
- 6.0.3
- 6.0.2
- 6.0.1
- 6.0.0
- 6.0.0-rc1
- 6.0.0-beta8
- 6.0.0-beta7
- 6.0.0-beta6
- 6.0.0-beta5
- 6.0.0-beta4
- 6.0.0-beta3
- 6.0.0-beta1
- 5.1.5
- 5.1.4
- 5.1.3
- 5.1.2
- 5.1.1
- 5.1.0
- 5.0.7
- 5.0.6
- 5.0.5
- 5.0.4
- 5.0.3
- 5.0.2
- 5.0.1
- 5.0.0
- 4.3.3
- 4.3.2
- 4.3.1
- 4.3.0
- 4.2.0
- 4.1.7
- 4.1.6
- 4.1.5
- 4.1.4
- 4.1.3
- 4.1.2
- 4.1.1
- 4.1.0
- 4.0.8
- 4.0.7
- 4.0.6
- 4.0.5
- 4.0.4
- 4.0.3
- 4.0.2
- 4.0.1
- 4.0.0
- 3.2.5
- 3.2.4
- 3.2.3
- 3.2.2
- 3.2.1
- 3.2.0
- 3.1.3
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.11
- 3.0.10
- 3.0.9
- 3.0.8
- 3.0.7
- 3.0.6
- 3.0.5
- 3.0.4
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 3.0.0-beta4
- 3.0.0-beta3
- 3.0.0-beta2
- 3.0.0-beta1
- 2.1.2
- 2.1.1
- 2.1.0
- 2.1.0-beta6
- 2.1.0-beta5
- 2.1.0-beta4
- 2.1.0-beta3
- 2.1.0-beta2
- 2.1.0-beta1
- 2.0.2
- 2.0.1
- 2.0.0
- 2.0.0-beta7
- 2.0.0-beta6
- 2.0.0-beta5
- 2.0.0-beta4
- 2.0.0-beta3
- 2.0.0-beta2
- 2.0.0-beta1
- 1.0.2
- 1.0.1
- 1.0.0
- 0.0.15
- 0.0.14
- 0.0.13
- 0.0.12
- 0.0.11
- 0.0.10
- 0.0.9
- 0.0.8
- 0.0.7
- 0.0.7-beta3
- 0.0.7-beta2
- 0.0.7-beta1
- 0.0.6
- 0.0.6-beta4
- 0.0.6-beta3
- 0.0.6-beta2
- 0.0.6-beta1
- 0.0.5
- 0.0.4
- 0.0.3
- 0.0.2
- 0.0.1
- 0.0.1-beta8
- 0.0.1-beta7
- 0.0.1-beta6
- 0.0.1-beta5
- 0.0.1-beta4
- 0.0.1-beta3
- 0.0.1-beta2
- 0.0.1-beta1
This package is auto-updated.
Last update: 2024-12-18 07:06:27 UTC
README
Universal package, following the #East programming philosophy, build on Teknoo/East-Foundation (and Teknoo/Recipe), and implementing a basic CMS to display dynamics pages with different types and templates.
Example with Symfony
//These operations are not reauired with teknoo/east-website-symfony
//config/packages/east_website_di.yaml:
di_bridge:
definitions:
- '%kernel.project_dir%/vendor/teknoo/east-website/src/di.php'
- '%kernel.project_dir%/vendor/teknoo/east-website/infrastructures/doctrine/di.php'
//bundles.php
...
Teknoo\East\WebsiteBundle\TeknooEastWebsiteBundle::class => ['all' => true],
//In doctrine config (east_website_doctrine_mongodb.yaml)
doctrine_mongodb:
document_managers:
default:
auto_mapping: true
mappings:
TeknooEastCommon:
type: 'xml'
dir: '%kernel.project_dir%/vendor/teknoo/east-common/infrastructures/doctrine/config/universal'
is_bundle: false
prefix: 'Teknoo\East\Common\Object'
TeknooEastWebsite:
type: 'xml'
dir: '%kernel.project_dir%/vendor/teknoo/east-website/infrastructures/doctrine/config/universal'
is_bundle: false
prefix: 'Teknoo\East\Website\Object'
TeknooEastWebsiteDoctrine:
type: 'xml'
dir: '%kernel.project_dir%/vendor/teknoo/east-website/infrastructures/doctrine/config/doctrine'
is_bundle: false
prefix: 'Teknoo\East\Website\Doctrine\Object'
//In security.yaml
security:
providers:
with_password:
id: 'Teknoo\East\CommonBundle\Provider\PasswordAuthenticatedUserProvider'
password_hashers:
Teknoo\East\CommonBundle\Object\PasswordAuthenticatedUser:
algorithm: '%teknoo.east.common.bundle.password_authenticated_user_provider.default_algo%'
//In routes/website.yaml
admin_website:
resource: '@TeknooEastWebsiteBundle/Resources/config/admin_routing.yaml'
prefix: '/admin'
admin_common:
resource: '@TeknooEastCommonBundle/Resources/config/admin_routing.yaml'
prefix: '/admin'
website:
resource: '@TeknooEastWebsiteBundle/Resources/config/routing.yaml'
Support this project
This project is free and will remain free. It is fully supported by the activities of the EIRL. If you like it and help me maintain it and evolve it, don't hesitate to support me on Patreon or Github.
Thanks :) Richard.
Credits
EIRL Richard Déloge - https://deloge.io - Lead developer. SASU Teknoo Software - https://teknoo.software
About Teknoo Software
Teknoo Software is a PHP software editor, founded by Richard Déloge, as part of EIRL Richard Déloge. Teknoo Software's goals : Provide to our partners and to the community a set of high quality services or software, sharing knowledge and skills.
License
East Website is licensed under the MIT License - see the licenses folder for details.
Installation & Requirements
To install this library with composer, run this command :
composer require teknoo/east-website
To start a project with Symfony :
symfony new your_project_name new
composer require teknoo/east-website-symfony
This library requires :
* PHP 8.1+
* A PHP autoloader (Composer is recommended)
* Teknoo/Immutable.
* Teknoo/States.
* Teknoo/Recipe.
* Teknoo/East-Foundation.
* Optional: Symfony 6.3+ (for administration)
News from Teknoo Website 9.x
This library requires PHP 8.1 or newer and it's only compatible with Symfony 6.3 or newer.
- Support last version of PHP DI 7 et Diactoros 3
- Automatic cleaning of rendered HTML thanks to tidy
News from Teknoo Website 8.x
This library requires PHP 8.1 or newer and it's only compatible with Symfony 6.2 or newer.
- Users and Media are migrated to East Common
- Dynamic texts can be sanitized thanks to Symfony Sanitizer (if you use Symfony Form)
- You can persists directly sanitized contents
- Add helpers to fetch directly these sanitized contents
- Add
ReadOnlyArray
to simulate a read only array' - Optimization of Menu Generator
News from Teknoo Website 7.x
This library requires PHP 8.1 or newer and it's only compatible with Symfony 6.0 or newer.
- Support Recipe 4.1.1+
- Support East Foundation 6.0.1+
- Public constant are final
- Block's types are Enums
- Direction are Enums
- Use readonly properties behaviors on Immutables
- Remove support of deprecated features removed in
Symfony 6.0
(Salt
,LegacyUser
) - Use
(...)
notation instead array notation for callable - Enable fiber support in front endpoint
QueryInterface
has been splitted toQueryElementInterface
andQueryCollectionInterface
to differentiate queries fetching only one element, or a scalar value, and queries for collections of objects.LoaderInterface::query
method is only dedicated forQueryCollectionInterface
queries.- a new method
LoaderInterface::fetch
is dedicated forQueryElementInterface
queries.
- Warning * : All legacy user are not supported from this version. User's salt are also not supported, all users' passwords must be converted before switching to this version.
News from Teknoo Website 6.x
This library requires PHP 8.0 or newer and it's only compatible with Symfony 5.3 or newer
- Add
UserInterface
to represent and User in a Eastt Website / WebApp. - Add
AuthDataInterface
to represent any data/credentials, able to authenticate an user - Update
User
class to following the previeous interface - Split authentications data from
User
class to a dedicated classStoredPassword
- Support password already hashed into
StoredPassword
- Update Doctrine ODM mappingg about
User
ans addStoredPassword
- Support third-party authentication.
- Add
ThirdPartyAuth
to store ids data from thrid party needed to authenticate an user. - Add
AbstractPassordAuthUser
to wrap password logic in Symfony User forLegacyUser
andPasswordAuthenticatedUser
. AbstractUser
can be also used for non password authenticated user.- Create
PasswordAuthenticatedUser
to implements new Symfony's interfacePasswordAuthenticatedUserInterface
- Update
SymfonyUserWriter
implementation in Symfony to hash password only when its needed. - Rework
UserProvider
toPasswordAuthenticatedUserProvider
to return aLegacyUser
if the user use the legacy Symfony behavior with a slug or aPasswordAuthenticatedUser
. It is able to migrate logged user to the new behavior, update the hashed ppassword passed by Symfony and remove salt. - Some QA fixes on PHPDoc
- Remove deprecated
ViewParameterInterface
- Remove deprecated Symfony
User
class - Create
StoredPasswordType
to manage new user in a Symfony Form. - Fix some bug in admin routes.
- Update annd fix some minor bug in Doctrinemapping
- Create
OAuth2Authenticator
, built on KNPU OAuth2 client bundle to authenticate user thanks to a OAuth2 provider.
News from Teknoo Website 5.x
This library requires PHP 8.0 or newer and it's only compatible with Symfony 5.2 or newer
- Migrate to PHP 8.0
- Writers services, Deleting services, and interfaces use also
Teknoo\East\Common\Contracts\Object\ObjectInterface
. - Create
Teknoo\East\Common\Contracts\Object\ObjectInterface
,Teknoo\East\Common\Contracts\Object\IdentifiedObjectInterface
extends it dedicated to non persisted object, manipulable by other components - Update steps and forms interface to use this new interface
- Replace ServerRequestInterface to MessageInterface for ListObjectAccessControlInterface and ObjectAccessControlInterface
- Switch Render steps to MessageInterface
- Add
ExprConversionTrait::addExprMappingConversion
to allow your custom evaluation of expression - Add
ObjectReference
expression to filter on reference - CreateObject step has a new parameter
$workPlanKey
to custom the key to use to store the new object in the workplan - CreateObject, DeleteObject, LoadObject, SaveObject and SlugPreparation use
Teknoo\East\Common\Contracts\Object\ObjectInterface
insteadTeknoo\East\Common\Contracts\Object\IdentifiedObjectInterface
. SaveObject pass the id only if the object implements this last object
News from Teknoo Website 4.x
This library requires PHP 7.4 or newer and it's only compatible with Symfony 4.4 or newer
- Migrate to Recipe 2.3+ and Tekno 3.3
- Migrate all classics services endpoints to Plan and Recipe.
- Remove all traits in main namespace with implementation in infrastructures namespaces.
- All plans and recipes, and majors of step are defined in the main namespace, only specialized steps are defined in infrastructures namespace.
- Remove AdminEditEndPoint, AdminListEndPoint, AdminNewEndPoint, ContentEndPointTrait and MediaEndPointTrait.
- Update Symfony configuration to manage this new architecture. Remove all services dedicated for each objects in Website, replaced by only agnostic endpoint. All configuration is pass in route.
News from Teknoo Website 3.x
This library requires PHP 7.4 or newer and it's only compatible with Symfony 4.4 or newer
- Migrate to Doctrine ODM 2
- Migrate to new GridFS Repository
- Migrate Gedmo's Timestamp to intern function and service
- Migrate Gedmo's Slug to intern function and service
- Migrate to Doctrine XML Mapping
- Reworking Translation : Fork Gedmo Translation, clean, simplify, rework, in East philosophy
- Remove Gedmo
- Create new Translation configuration
- Pagination Query support countable
- ContentType and ItemType are not hardcoded to use DocumentType, but a Type passed in options via the EndPoint
- Optimize menu to limit requests
- Expr In Agnostic support
- Change Doctrine Repository behavior to create classes dedicated to ODM
- Create Common repository for non ODM with fallback feature
- Autoselect Good Repository in DI
- Migrate MediaEndPoint into ODM namespace
- Add ProxyDetectorInterface and a snippet into DI to detect if an object is behind a proxy agnosticaly
- Require to East Foundation 3.0.0
- Fix errors in services definitions
- Change exception management into MediaEndPoint
News from Teknoo Website 2.x
This library requires PHP 7.4 or newer and it's only compatible with Symfony 4.4 or newer, Some change causes bc breaks :
- PHP 7.4 is the minimum required
- Replace array_merge by "..." operators
- Remove some PHP useless DockBlocks
- Switch to typed properties
- Most methods have been updated to include type hints where applicable. Please check your extension points to make sure the function signatures are correct. _ All files use strict typing. Please make sure to not rely on type coercion.
- Set default values for Objects.
- Set dependencies defined into PHP-DI used in Symfony as synthetic services into Symfony's services definitions to avoid compilation error with Symfony 4.4
- Enable PHPStan in QA Tools and disable PHPMd
- Enable PHPStan extension dedicated to support Stated classes
Contribute :)
You are welcome to contribute to this project. Fork it on Github