jairwin / contact-bundle
This bundle provides a basic feedback implementation for symfony 3 projects
Installs: 160
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
Open Issues: 0
Type:symfony-bundle
Requires
- excelwebzone/recaptcha-bundle: ^1.4.2
README
This bundle provides a basic feedback implementation for Symfony 3 projects.
Installation
Step 1: Download the Bundle
Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:
$ composer require jairwin/contact-bundle "~1"
This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.
Step 2: Enable the Bundle
Then, enable the bundle and required bundle by adding them to the list of registered bundles
in the app/AppKernel.php
file of your project:
<?php // app/AppKernel.php // ... class AppKernel extends Kernel { public function registerBundles() { $bundles = array( // ... new EWZ\Bundle\RecaptchaBundle\EWZRecaptchaBundle(), new JAI\Bundle\ContactBundle\JAIContactBundle(), ); // ... } // ... }
Step 3: Add Routing
To add the provided routes for /contact and /contact/success update
app/config/routing.yml
:
# app/config/routing.yml jai_contact: resource: "@JAIContactBundle/Resources/config/routing.yml" prefix: /
Step 4: Configure ReCaptcha
This bundle uses the EZWRecaptchaBundle which is configured in app/config/config.yml
(documentation: EWZRecaptcha on GitHub):
# app/config/config.yml ewz_recaptcha: public_key: here_is_your_public_key private_key: here_is_your_private_key locale_key: %kernel.default_locale%
For development you need to provide separate configuratons using the public test keys everywhere except production (documentation: Google Recaptcha FAQ). You could either store the keys in parameters.yml
or add the ewz_recaptcha
configurations to config_dev.yml
, config_prod.yml
, and config_test.yml
instead of config.yml
.
Step 5: Enable Translations
To get the correct form labels and placeholders enable translation. In a new Symfony3
project it needs to be uncommented in app/config/config.yml
:
# app/config/config.yml framework: translator: { fallbacks: ["%locale%"] }
And set the locale in app/config/parameters.yml
:
# app/config/parameters.yml locale: en
Note - so far only english translations have been provided in this bundle. Most of the defaults are rather ugly.
Step 6: Configure Recipient
This bundle sends all contact emails to a single address. This is configured in
app/config/parameters.yml
:
# app/config/parameters.yml # JAI Contact Bundle Configuration feedback_email: address@yoursite.tld
Using
Once installed and configured the contact form can be reached at the route \contact
. The form uses the
Symfony Forms Component (documentation: Forms from the Symfony Book),
so it will use the form themes (documentation: Form Themes from the Symfony Book).
To-Do
Unit Testing
Currently there aren't any unit tests, and that's just not right.
Better Handling of Configuration
Should probably move feedback_email from parameters.yml to config.yml and add more configurable settings.
Flood Control
Could stop some bot attacks before they hit the form in the first place.
Remove Dependency on EZWRecaptchaBundle
It would be better if there was an optional setting like "use captcha" and then further settings such as only requiring after a certain amount of flooding, and then specifics related to whatever captcha implementation is used in the current project.
Multiple To Addresses
Configure optional topic selection that would allow the user to select a topic for the feedback that would address the email to different recipients. Some examples:
"Website Issues" => "webmaster@domain.tld"
"Billing Issues" => "accounting@domain.tld"
"General Feedback" => "feedback@domain.tld"