Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aimeos/aimeos-symfony
Symfony e-commerce bundle for professional, ultra fast online shops, complex B2B applications and #gigacommerce
https://github.com/aimeos/aimeos-symfony
aimeos b2b e-commerce ecommerce json-api marketplace performance php shop symfony symfony-ecommerce-bundle
Last synced: 4 days ago
JSON representation
Symfony e-commerce bundle for professional, ultra fast online shops, complex B2B applications and #gigacommerce
- Host: GitHub
- URL: https://github.com/aimeos/aimeos-symfony
- Owner: aimeos
- License: mit
- Created: 2014-09-17T21:00:42.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2024-09-10T08:09:28.000Z (4 months ago)
- Last Synced: 2024-09-10T10:21:53.014Z (4 months ago)
- Topics: aimeos, b2b, e-commerce, ecommerce, json-api, marketplace, performance, php, shop, symfony, symfony-ecommerce-bundle
- Language: CSS
- Homepage: https://aimeos.org/Symfony
- Size: 7.72 MB
- Stars: 231
- Watchers: 17
- Forks: 52
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Aimeos Symfony bundle
[![Total Downloads](https://poser.pugx.org/aimeos/aimeos-symfony/d/total.svg)](https://packagist.org/packages/aimeos/aimeos-symfony)
[![Build Status](https://travis-ci.org/aimeos/aimeos-symfony.svg?branch=master)](https://travis-ci.org/aimeos/aimeos-symfony)
[![Coverage Status](https://coveralls.io/repos/aimeos/aimeos-symfony/badge.svg?branch=master)](https://coveralls.io/r/aimeos/aimeos-symfony?branch=master)
[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/aimeos/aimeos-symfony/badges/quality-score.png?b=master)](https://scrutinizer-ci.com/g/aimeos/aimeos-symfony/?branch=master):star: Star us on GitHub — it helps!
[Aimeos](https://aimeos.org/Symfony) is THE professional, full-featured and
ultra fast e-commerce package for Symfony! You can install it in your existing
Symfony application within 5 minutes and can adapt, extend, overwrite and
customize anything to your needs.[![Aimeos Symfony demo](https://aimeos.org/fileadmin/aimeos.org/images/aimeos-github.png)](http://symfony.demo.aimeos.org/)
## Table of content
- [Installation](#installation)
- [Composer](#composer)
- [Admin](#admin)
- [Hints](#hints)
- [License](#license)
- [Links](#links)## Installation
This document is for the latest **Aimeos 2023.10** and **Symfony 6.3+**.
If you want to **upgrade between major versions**, please have a look into the [upgrade guide](https://aimeos.org/docs/Symfony/Upgrade)!
The Aimeos Symfony e-commerce bundle is a composer based library that can be installed
easiest by using [Composer](https://getcomposer.org). If you don't have an existing
Symfony application, you can create a skeleton application using```
composer create-project symfony/website-skeleton:~4.4 myshop
cd myshop
```These settings need to be added to the `./config/packages/fos_user.yaml` file:
```yaml
fos_user:
db_driver: orm
user_class: Aimeos\ShopBundle\Entity\FosUser
firewall_name: aimeos_myaccount
from_email:
address: "[email protected]"
sender_name: "Test shop"
service:
mailer: 'fos_user.mailer.noop'
```The Aimeos components have to be configured as well to get authentication working correctly.
You need to take care of three things: Using the correct customer manager implementation and
password encryption method as well as the right path for the storages. All must be appended
at the end of the `./config/packages/aimeos_shop.yaml`:```yaml
aimeos_shop:
resource:
fs:
baseurl: "https://yourdomain.com/"
basedir: "%kernel.project_dir%/public"
fs-admin:
basedir: "%kernel.project_dir%/public/uploads"
mshop:
customer:
manager:
name: FosUser
password:
name: Bcrypt
```To configure the Aimeos routing, create the file `./config/routes/aimeos_shop.yaml` with these lines:
```yaml
aimeos_shop:
resource: "@AimeosShopBundle/config/routing.yaml"
```The same applies for the FosUser bundle. Create the file `./config/routes/fos_user.yaml` containing:
```yaml
fos_user:
resource: "@FOSUserBundle/Resources/config/routing/all.xml"
```Make sure that the database is set up and it is configured in your `./config/packages/doctrine.yaml`:
```yaml
parameters:
env(DATABASE_URL): ''
database_host:
database_port:
database_name:
database_user:
database_password:
```Also, you have to configure your database credentials in the `.env` file:
`DATABASE_URL=mysql://db_user:[email protected]:3306/db_name`
If you want to use a database server other than MySQL, please have a look into the article about
[supported database servers](https://aimeos.org/docs/latest/infrastructure/databases/)
and their specific configuration.If you don't use Sendmail but SMTP for sending e-mails, you have to adapt the `MAILER_URL`
configuration in your `.env` file, e.g.:`MAILER_URL=smtp://smtp.mailtrap.io:2525?encryption=tls&auth_mode=login&username=...&password=...`
## Composer
Then add these lines to your `composer.json` of your Symfony project:
```json
"prefer-stable": true,
"minimum-stability": "dev",
"require": {
"aimeos/aimeos-symfony": "~2023.10",
"friendsofsymfony/user-bundle": "^3.2",
...
},
"scripts": {
"post-install-cmd": [
"Aimeos\\ShopBundle\\Composer\\ScriptHandler::installBundle",
"Aimeos\\ShopBundle\\Composer\\ScriptHandler::setupDatabase",
...
],
"post-update-cmd": [
"Aimeos\\ShopBundle\\Composer\\ScriptHandler::installBundle",
"Aimeos\\ShopBundle\\Composer\\ScriptHandler::setupDatabase",
...
]
}
```Afterwards, install the Aimeos shop bundle using
`composer update`
In a production environment or if you don't want that the demo data gets installed,
use the --no-dev option:`SYMFONY_ENV=prod composer update --no-dev`
If you get an exception that the `SensioGeneratorBundle` isn't found, follow the
steps described in the
[Aimeos Symfony forum post](https://aimeos.org/help/symfony-bundle-f17/symfony-env-prod-composer-update-no-dev-t1488.html#p6384)Start the PHP web server in the base directory of your application to do some quick tests:
```php -S 127.0.0.1:8000 -t public```
Then, you should be able to call the catalog list page in your browser using
```http://127.0.0.1:8000/shop```
## Login and Admin
Setting up the administration interface is a matter of configuring the Symfony
firewall to restrict access to the admin URLs.Setting up the security configuration is the most complex part. The firewall
setup in `./config/packages/security.yaml` should look like this one:```yaml
security:
providers:
aimeos:
entity: { class: Aimeos\ShopBundle\Entity\FosUser, property: username }password_hashers:
Aimeos\ShopBundle\Entity\FosUser: bcryptfirewalls:
aimeos_admin:
pattern: ^/admin
provider: aimeos
form_login:
login_path: /admin
check_path: /admin_check
aimeos_myaccount:
pattern: ^/
form_login:
provider: aimeos
csrf_token_generator: security.csrf.token_manager
logout: trueaccess_control:
- { path: ^/login$, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/register, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/resetting, role: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/profile, roles: ROLE_USER }
- { path: ^/admin/.+, roles: [ROLE_ADMIN, ROLE_SUPER_ADMIN] }
```**Caution:** The order of the configuration settings in this file is important!
These settings will protect the ```/admin/*``` URLs from unauthorized access from
someone without admin privileges.The `/profile` URL is protected by the FOS user bundle as well, which also offers
user registration.As last step, you have to create an admin account using the Symfony command line:
```bash
./bin/console aimeos:account --admin [email protected]
```The e-mail address is the user name for login and the account will work for the frontend too.
To protect the new account, the command will ask you for a password. The same command can
create limited accounts by using "--editor" instead of "--admin". If you use "--super" the
account will have access to all sites.If the PHP web server is still running (`php -S 127.0.0.1:8000 -t public`), you should be
able to call the admin login page in your browser using```http://127.0.0.1:8000/admin```
and authenticating with your e-mail and the password which has been asked for by the
`aimeos:account` command.## Hints
To simplify development, you should configure to use no content cache. You can
do this by adding these lines to `./config/packages/aimeos_shop.yaml`:```yaml
aimeos_shop:
madmin:
cache:
manager:
name: None
```## License
The Aimeos Symfony bundle is licensed under the terms of the MIT license and is available for free.
## Links
* [Web site](https://aimeos.org/Symfony)
* [Documentation](https://aimeos.org/docs/latest/symfony/)
* [Forum](https://aimeos.org/help/symfony-bundle-f17/)
* [Issue tracker](https://github.com/aimeos/aimeos-symfony/issues)
* [Composer packages](https://packagist.org/packages/aimeos/aimeos-symfony)
* [Source code](https://github.com/aimeos/aimeos-symfony)