-
To have better control over the serialization process, we introduced
shop
andadmin
prefixes to names of serialization groups onsrc/Sylius/Bundle/ApiBundle/Resources/config/api_resources/*
andsrc/Sylius/Bundle/ApiBundle/Resources/config/serialization/*
. Several additional serialization groups have been rephrased, to improve readability and predictability of them. If you are using they on your custom entityapi_resource
configuration or serialization groups, you should check if one of these changes may affect on your app. If yes, change all occurs by this pattern:admin_user:create
changed to:admin:admin_user:create
admin_user:read
changed to:admin:admin_user:read
admin_user:update
changed to:admin:admin_user:update
avatar_image:read
changed to:admin:avatar_image:read
channel:create
changed to:admin:channel:create
channel:read
changed to:admin:channel:read
country:read
changed to:admin:country:read
currency:read
changed to:admin:currency:read
customer:password:write
changed to:shop:customer:password:update
customer:read
changed to:admin:customer:read
andshop:customer:read
customer:update
changed to:shop:customer:update
shop:currencies:read
changed to:shop:currency:read
shop:customer:write
changed to:shop:customer:create
-
Change configuration of new ApiBundle in your
config/packages/security.yaml
file:security: firewalls: new_api_admin_user: json_login: - check_path: "%sylius.security.new_api_route%/admin/authentication-token" + check_path: "%sylius.security.new_api_admin_route%/authentication-token" new_api_shop_user: json_login: - check_path: "%sylius.security.new_api_route%/shop/authentication-token" + check_path: "%sylius.security.new_api_shop_route%/authentication-token" access_control: - - { path: "%sylius.security.new_api_route%/admin/authentication-token", role: IS_AUTHENTICATED_ANONYMOUSLY } + - { path: "%sylius.security.new_api_admin_route%/authentication-token", role: IS_AUTHENTICATED_ANONYMOUSLY } - - { path: "%sylius.security.new_api_route%/shop/authentication-token", role: IS_AUTHENTICATED_ANONYMOUSLY } + - { path: "%sylius.security.new_api_shop_route%/authentication-token", role: IS_AUTHENTICATED_ANONYMOUSLY }
-
The
sylius:cancel-unpaid-orders
command now continues to proceed even if an error occurred. The behavior here is now normal but it leads to a few issues for an upgrade:- Product variants with
on_hold = on_hand
will become available as soon as the uncancelled orders are now cancelled. This could lead to a lot of products on sale which were not previously on sale. This behavior is normal but the Merchant could be used to the previous behavior and could have acted around it.
Before you upgrade on production you may want to verify the stocks of these products variants:
SELECT code FROM sylius_product_variant WHERE on_hand = on_hold; -- These products will go back on "available" and may be sold
- If the merchant is used to this (now gone) bug, then they should be careful about this situation as well: if they worked with the issue and considered that increasing the
on_hand
value to sale more since some on hand stocks were locked by theon_hold
items, they may be in the situation of having more items on hand than the reality.
- Product variants with
-
Change configuration of new ApiBundle in your
config/packages/security.yaml
file:security: providers: - sylius_api_chain_provider: - chain: - providers: [sylius_api_shop_user_provider, sylius_api_admin_user_provider] firewalls: new_api_admin_user: - pattern: "%sylius.security.new_api_route%/admin-user-authentication-token" - provider: sylius_admin_user_provider + pattern: "%sylius.security.new_api_admin_regex%/.*" + provider: sylius_api_admin_user_provider json_login: - check_path: "%sylius.security.new_api_route%/admin-user-authentication-token" + check_path: "%sylius.security.new_api_route%/admin/authentication-token" new_api_shop_user: - pattern: "%sylius.security.new_api_route%/shop-user-authentication-token" - provider: sylius_shop_user_provider + pattern: "%sylius.security.new_api_shop_regex%/.*" + provider: sylius_api_shop_user_provider json_login: - check_path: "%sylius.security.new_api_route%/shop-user-authentication-token" + check_path: "%sylius.security.new_api_route%/shop/authentication-token" - new_api: - pattern: "%sylius.security.new_api_regex%/*" - provider: sylius_api_chain_provider - stateless: true - anonymous: lazy - guard: - authenticators: - - lexik_jwt_authentication.jwt_token_authenticator access_control: + - { path: "%sylius.security.new_api_route%/admin/authentication-token", role: IS_AUTHENTICATED_ANONYMOUSLY } + - { path: "%sylius.security.new_api_route%/shop/authentication-token", role: IS_AUTHENTICATED_ANONYMOUSLY }
-
Add new bundles to your list of used bundles in
config/bundles.php
if you are not using it apart from Sylius:+ ApiPlatform\Core\Bridge\Symfony\Bundle\ApiPlatformBundle::class => ['all' => true], + Sylius\Bundle\ApiBundle\SyliusApiBundle::class => ['all' => true], + Lexik\Bundle\JWTAuthenticationBundle\LexikJWTAuthenticationBundle::class => ['all' => true], + SyliusLabs\DoctrineMigrationsExtraBundle\SyliusLabsDoctrineMigrationsExtraBundle::class => ['all' => true],
-
Add configuration of new ApiBundle in your
config/packages/_sylius.yaml
file:imports: + - { resource: "@SyliusApiBundle/Resources/config/app/config.yaml" }
-
Add configuration of new ApiBundle in your
config/packages/security.yaml
file:parameters: - sylius.security.admin_regex: "^/admin" - sylius.security.shop_regex: "^/(?!admin|api/.*|api$|media/.*)[^/]++" + sylius.security.admin_regex: "^/%sylius_admin.path_name%" + sylius.security.shop_regex: "^/(?!%sylius_admin.path_name%|new-api|api/.*|api$|media/.*)[^/]++" + sylius.security.new_api_route: "/new-api" + sylius.security.new_api_regex: "^%sylius.security.new_api_route%" + sylius.security.new_api_admin_route: "%sylius.security.new_api_route%/admin" + sylius.security.new_api_admin_regex: "^%sylius.security.new_api_admin_route%" + sylius.security.new_api_shop_route: "%sylius.security.new_api_route%/shop" + sylius.security.new_api_shop_regex: "^%sylius.security.new_api_shop_route%" security: providers: + sylius_api_admin_user_provider: + id: sylius.admin_user_provider.email_or_name_based + sylius_api_shop_user_provider: + id: sylius.shop_user_provider.email_or_name_based + sylius_api_chain_provider: + chain: + providers: [sylius_api_shop_user_provider, sylius_api_admin_user_provider] firewalls: admin: remember_me: - path: /admin + path: "/%sylius_admin.path_name%" + new_api_admin_user: + pattern: "%sylius.security.new_api_route%/admin-user-authentication-token" + provider: sylius_admin_user_provider + stateless: true + anonymous: true + json_login: + check_path: "%sylius.security.new_api_route%/admin-user-authentication-token" + username_path: email + password_path: password + success_handler: lexik_jwt_authentication.handler.authentication_success + failure_handler: lexik_jwt_authentication.handler.authentication_failure + guard: + authenticators: + - lexik_jwt_authentication.jwt_token_authenticator + + new_api_shop_user: + pattern: "%sylius.security.new_api_route%/shop-user-authentication-token" + provider: sylius_shop_user_provider + stateless: true + anonymous: true + json_login: + check_path: "%sylius.security.new_api_route%/shop-user-authentication-token" + username_path: email + password_path: password + success_handler: lexik_jwt_authentication.handler.authentication_success + failure_handler: lexik_jwt_authentication.handler.authentication_failure + guard: + authenticators: + - lexik_jwt_authentication.jwt_token_authenticator + + new_api: + pattern: "%sylius.security.new_api_regex%/*" + provider: sylius_api_chain_provider + stateless: true + anonymous: lazy + guard: + authenticators: + - lexik_jwt_authentication.jwt_token_authenticator + access_control: + - { path: "%sylius.security.new_api_admin_regex%/.*", role: ROLE_API_ACCESS } + - { path: "%sylius.security.new_api_shop_regex%/.*", role: IS_AUTHENTICATED_ANONYMOUSLY }
-
Add
sylius_api.yaml
file toconfig/routes/
directory:sylius_api: resource: "@SyliusApiBundle/Resources/config/routing.yml" prefix: "%sylius.security.new_api_route%"
-
Add
lexik_jwt_authentication.yaml
file toconfig/packages/
directory:lexik_jwt_authentication: secret_key: '%env(resolve:JWT_SECRET_KEY)%' public_key: '%env(resolve:JWT_PUBLIC_KEY)%' pass_phrase: '%env(JWT_PASSPHRASE)%'
-
Add configuration in your
.env
file:+ ###> lexik/jwt-authentication-bundle ### + JWT_SECRET_KEY=%kernel.project_dir%/config/jwt/private.pem + JWT_PUBLIC_KEY=%kernel.project_dir%/config/jwt/public.pem + JWT_PASSPHRASE=YOUR_SECRET_PASSPHRASE + ###< lexik/jwt-authentication-bundle ###
-
Add configuration in your
.env.test
file:+ ###> lexik/jwt-authentication-bundle ### + JWT_SECRET_KEY=%kernel.project_dir%/config/jwt/private-test.pem + JWT_PUBLIC_KEY=%kernel.project_dir%/config/jwt/public-test.pem + JWT_PASSPHRASE=ALL_THAT_IS_GOLD_DOES_NOT_GLITTER_NOT_ALL_THOSE_WHO_WANDER_ARE_LOST + ###< lexik/jwt-authentication-bundle ###
-
Add configuration in your
.env.test_cached
file:+ ###> lexik/jwt-authentication-bundle ### + JWT_SECRET_KEY=%kernel.project_dir%/config/jwt/private-test.pem + JWT_PUBLIC_KEY=%kernel.project_dir%/config/jwt/public-test.pem + JWT_PASSPHRASE=ALL_THAT_IS_GOLD_DOES_NOT_GLITTER_NOT_ALL_THOSE_WHO_WANDER_ARE_LOST + ###< lexik/jwt-authentication-bundle ###
-
Sample JWT token generation is available here
-
All consts classes has been changed from final classes to interfaces. As a result initialization of
\Sylius\Bundle\UserBundle\UserEvents
is not longer possible. The whole list of changed classes can be found here. -
Service alias
Sylius\Component\Channel\Context\ChannelContextInterface
was changed fromsylius.context.channel.composite
tosylius.context.channel
. The later is being decorated bysylius.context.channel.cached
which caches the channel per request and reduces the amount of database queries. -
A serialization group has been added to the route
sylius_admin_ajax_product_index
to avoid an infinite loop, or a time out during this ajax request (previously no serialization group was defined on this route). -
We now use the parameter
sylius_admin.path_name
to retrieve the admin routes prefix. If you used the/admin
prefix in some admin URLs you can now replace/admin
by/%sylius_admin.path_name%
.
Also the route is now dynamic. You can change theSYLIUS_ADMIN_ROUTING_PATH_NAME
environment variable to custom the admin's URL.
As we switched to the 3.0
version of Doctrine Migrations, there are some things that need to be changed in the application that is upgraded to Sylius 1.8:
-
Replace the DoctrineMigrationsBundle configuration in
config/packages/doctrine_migrations.yaml
:doctrine_migrations: - dir_name: "%kernel.project_dir%/src/Migrations" - - # Namespace is arbitrary but should be different from App\Migrations as migrations classes should NOT be autoloaded - namespace: DoctrineMigrations + storage: + table_storage: + table_name: sylius_migrations + migrations_paths: + 'DoctrineMigrations': '%kernel.project_dir%/src/Migrations'
-
Remove all the legacy Sylius-Standard migrations (they're not needed anymore)
rm "src/Migrations/Version20170912085504.php" #...
-
Mark all migrations from @SyliusCoreBundle and @SyliusAdminApiBundle as executed (they're the same as legacy ones, just not recognized by the doctrine yet)
bin/console doctrine:migrations:version "Sylius\Bundle\CoreBundle\Migrations\Version20161202011555" --add --no-interaction #...
BEWARE!
If you're using some Sylius plugins you'll probably need to handle their migrations as well. You can either leave them in your
src/Migrations/
catalog and treat as your own or use the migrations from the vendors. However, it assumes that plugin provides a proper integration with Doctrine Migrations 3.0 - as, for example, Invoicing Plugin.TIP
Take a look at etc/migrations-1.8.sh script - it would execute points 2) and 3) automatically.
-
Do the same for your own migrations. Assuming your migrations namespace is
DoctrineMigrations
and migrations catalog issrc/Migrations
, you can run such a script:#!/bin/bash for file in $(ls -1 src/Migrations/ | sed -e 's/\..*$//') do bin/console doctrine:migrations:version "DoctrineMigrations\\${file}" --add --no-interaction done
-
Run
bin/console doctrine:migrations:migrate
to apply migrations added in Sylius 1.8
In the migrations of the 1.8 we add a flag enabled
on the product variants and the taxons. This flag is on 0
by default, which leads to an empty catalog and some errors due to products without enabled variants.
To resolve this, you should run these two SQL requests on production:
UPDATE sylius_taxon SET enabled = 1;
UPDATE sylius_product_variant SET enabled = 1;
This could also be done in a Migration as well if you prefer. You can create an empty migration (then you can fill it!) like this:
./bin/console doctrine:migrations:generate
Some translations have changed, you may want to search for them in your project:
sylius.email.shipment_confirmation.tracking_code
has been removed.sylius.email.shipment_confirmation.you_can_check_its_location
has been removed.sylius.email.shipment_confirmation.you_can_check_its_location_with_the_tracking_code
has been added instead of the two above.