basilicom-pimcore-plugin / participation
Framework to help building raffles and subscriptions
Installs: 134
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 1
Open Issues: 3
Type:pimcore-plugin
pkg:composer/basilicom-pimcore-plugin/participation
Requires
- php: >=5.4.0
- ircmaxell/random-lib: ^1.1
- pimcore/installer-plugin: ~1.3
This package is auto-updated.
Last update: 2025-10-10 00:40:07 UTC
README
Developer info: Pimcore at basilicom
Synopsis
This Pimcore http://www.pimcore.org plugin simplifies building a site with participations, e.g. raffles.
Method of Operation
A user visiting the /participation-demo-simple page/url gets a form (with a captcha).
Upon completing the captcha, filling out the form and submitting it, a new Participation
object (key is constructed using time() and a random value) is added to the
/participation object folder and an email /participation-confirmation is send to
the user. If the User clicks on the confirmation link in the received email, his
Participation object is retrieved by looking up the confirmation code and setting the
objects isConfirmed property to true. Notes are created the the objects in order to
document the individual steps.
The users IP is recorded during object creation / confirmation. Prior to sending the
email, the participation object is updated with an extra normalized domain part of
the users email address. These properties can later be used for additional/optional
fraud detection/prevention.
Motivation
Implementing raffles with participations is a recurring tedious task - prone to making many errors. This plugin tries to use as much "Best Practices" and standard Pimcore features as possible to simplify future implementations.
Installation
Add "basilicom-pimcore-plugin/participation" as a requirement to the composer.json in the toplevel directory of your Pimcore installation.
Example:
{
"require": {
"basilicom-pimcore-plugin/participation": "~1.0"
}
}
Installing the plugin via the Pimcore Extension Manager performs the following steps:
- an object class
Participationis created - an object folder
/participationis created - a predefined email document type
Participation Confirmationis created - a sample email document
/participation-confirmationis created - a demo document
/participation-demo-simpleis created - a static route
participationConfirmationCheckis created for@/confirm/(.*)@
Press the "Configure" button of the Participation plugin from within the Extension Manager and set the config file properties.
Hint: Set demoEnabled to 1 if you want to test the /participation-demo-simple.
You need to apply for / configure a Google Recaptcha widget integration and
configure sitekey and secret in the plugin configuration file.
Refer to https://developers.google.com/recaptcha/intro for info on Google Recaptcha.
Customization
The Participation object class can be modified as long as the email field and
the fields of the Meta section are kept.
You can change the static route participationConfirmationCheck as long as you keep
the name and the code parameter intact.
Change the target folder for storing the Participations by altering the objectFolderPath
configuration option.
Change the email document used by altering the emailDocumentPath configuration option.
Provide custom participation confirmation success/failure pages by changing the
configuration options confirmationSuccessUrl and confirmationFailureUrl.
For further customization, extend the Manager class and (optionally) one or more of the Confirmation and ReCaptcha classes or implement the corresponding interfaces. You need to register your new Manager class by specifying the full class name in the plugin configuration file.
API Reference
The following interfaces are provided:
\Participation\ManagerInterface\Participation\ConfirmationInterface\Participation\CaptchaInterface
Tests
- none
Todo
- Add an Ajax-based form demo.
- Add re-usable AreaBricks
- Implement the possibility to use multiple/different participations in one pimcore installation
- Implement IP-based throtteling (via leaky bucket)
- Implement email-domain-based throtteling (via leaky bucket)
- Add Application Log logging
Contributors
- Susanna Huhtanen susanna.huhtanen@basilicom.de
- Christoph Luehr christoph.luehr@basilicom.de
License
- BSD-3-Clause