exs / lander-tracking-house-bundle
This bundle manages query tracking parameters.
Installs: 1 295
Dependents: 3
Suggesters: 0
Security: 0
Stars: 0
Watchers: 8
Forks: 0
Open Issues: 0
Type:symfony-bundle
pkg:composer/exs/lander-tracking-house-bundle
Requires
- php: ~5.5|~7.0
- symfony/framework-bundle: ~2.8|~3.0
- twig/twig: ~1.23|~2.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.7
- phpstan/phpstan: ^0.8.5
- phpunit/phpunit: ~4.8
README
What is this bundle doing ?
This bundle searches for tracking parameters in the request.
Stores the tracking parameters in cookies.
And then add those tracking parameters to any url using Formatter services.
Installation
Download the bundle using composer
$ composer require exs/lander-tracking-house-bundle
Enable the bundle
<?php // app/AppKernel.php public function registerBundles() { $bundles = array( // ... new EXS\LanderTrackingHouseBundle\EXSLanderTrackingHouseBundle(), // ... ); }
Configuration
The cmp, exid and visit parameters have a default value configurable with those configuration keys :
# Default values. exs_lander_tracking_house: default_cmp: ~ default_exid: 'exid' default_visit: 1
Usage
Use the appendTracking Twig filter on any url.
If the user have got the required tracking parameters, the tracking parameters will be added.
Use a specific formatter
<a href="{{ 'https://www.foo.tld/bar' | appendTracking('foo') }}" target="_blank">Some link</a> <a href="{{ url('homepage') | appendTracking('foo') }}" target="_blank">Some link</a>
Replace placeholders
<a href="{{ url('homepage', {'cmp': '{cmp}', 'exid': '{exid}'}) | appendTracking }}" target="_blank">Some link</a> <a href="{{ 'https://www.foo.tld/bar?cmp={cmp}&exid={exid}&visit={visit}' | appendTracking }}" target="_blank">Some link</a>
Use getTracking('parameterName') Twig function to get any tracking parameter.
<input type="hidden" name="foo" value="{{ getTracking('foo') }}">
Builtin extractor
- cmpsearches for the parameter named- cmpin the request or the cookies. This parameter contains the- cmp's value and is extracted as internal parameter- cmp. If not found it will define a default value using- exs_lander_tracking_house.default_cmpconfiguration's parameter.
- cupsearches for the parameter named- cupin the request. This parameter contains a string composed of- {cmp}~{exid}~{product_id}and is extracted as internal parameters- cmp,- exidand- product_id.
- cusearches for the parameter named- cuin the request. This parameter contains a string composed of- {cmp}~{exid}and is extracted as internal parameters- cmpand- exid.
- cuvpsearches for the parameter named- cuvpin the request. This parameter contains a string composed of- {cmp}~{exid}~{visit}~{product_id}and is extracted as internal parameters- cmp,- exid,- visitand- product_id.
- cuvsearches for the parameter named- cuvin the request. This parameter contains a string composed of- {cmp}~{exid}~{visit}and is extracted as internal parameters- cmp,- exidand- visit.
- exidsearches for the parameter named- exidor- uor- uuidin the request or cookies (Will use the first match). This parameter contains the- exid's value and is extracted as internal parameters- exid. If not found it will define a default value using- exs_lander_tracking_house.default_exidconfiguration's parameter.
- product_idsearches for the parameter named- pin the request. This parameter contains the- product_id's value and is extracted as internal parameters- product_id.
- uvpsearches for the parameter named- uvpin the request. This parameter contains a string composed of- {exid}~{visit}~{product_id}and is extracted as internal parameters- exid,- visitand- product_id.
- uvsearches for the parameter named- uvin the request. This parameter contains a string composed of- {exid}~{visit}and is extracted as internal parameters- exidand- visit.
- visitsearches for the parameter named- visitin the request or cookies. This parameter contains the- visit's value and is extracted as internal parameters- visit. If not found it will define a default value using- exs_lander_tracking_house.default_visitconfiguration's parameter.
Builtin formatter
- cupwill use- cmp,- exidand- product_idinternal parameters to append the parameter- cupcomposed of- {cmp}~{exid}~{product_id}.
- cuwill use- cmpand- exidinternal parameters to append the parameter- cucomposed of- {cmp}~{exid}.
- cuvpwill use- cmp,- exid,- visitand- product_idinternal parameters to append the parameter- cuvpcomposed of- {cmp}~{exid}~{visit}~{product_id}.
- cuvwill use- cmp,- exidand- visitinternal parameters to append the parameter- cuvcomposed of- {cmp}~{exid}~{visit}.
- uvpwill use- exid,- visitand- product_idinternal parameters to append the parameter- uvpcomposed of- {exid}~{visit}~{product_id}.
- uvwill use- exidand- visitinternal parameters to append the parameter- uvcomposed of- {exid}~{visit}.
Adding an extracter
The bundle uses extracter services to find and get tracking parameters from the request, the cookies and/or define default value.
Those services have to implement EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterQueryExtracterInterface and/or EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterCookieExtracterInterface and/or EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterInitializerInterface.
All those methods have to return a key/value array of tracking parameters found that will be saved in cookies.
Example :
1. Creating the extractor class for a new parameter foo
<?php namespace My\SomeBundle\Service; use Symfony\Component\HttpFoundation\ParameterBag; use EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterCookieExtracterInterface; use EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterQueryExtracterInterface; use EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterInitializerInterface; class FooExtracter implements TrackingParameterCookieExtracterInterface, TrackingParameterQueryExtracterInterface, TrackingParameterInitializerInterface { public function extractFromQuery(ParameterBag $query) { $trackingParameters = []; if (null !== $foo = $query->get('foo')) { $trackingParameters['foo'] = $foo; } return $trackingParameters; } public function extractFromCookies(ParameterBag $cookies) { $trackingParameters = []; if (null !== $foo = $cookies->get('foo')) { $trackingParameters['foo'] = $foo; } return $trackingParameters; } public function initialize() { return [ 'foo' => 123, ]; } }
Important thing to notice here : All keys from the array returned by an extractFromQuery(), extractFromCookies() and initialise() will be stored as a cookie.
In the example ahead, a cookie named foo will be stored with the value found in query or in cookies or else will define the default value.
2. Declare the service with tag exs_tracking.parameter_extracter
services: exs_tracking.foo_extracter: class: 'My\SomeBundle\Service\FooExtracter' tags: - { name: 'exs_tracking.parameter_extracter' }
In case many extracters have an initialise() method defined, we can specify a priority to know which default value to use (Higher value wins).
services: exs_tracking.foo_extracter: class: 'My\SomeBundle\Service\FooExtracter' tags: - { name: 'exs_tracking.parameter_extracter', priotiry: 100 }
Adding a formatter
The bundle uses formatter services to get the parameters to append to an url.
Those services have to implements EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterFormatterInterface.
They have to implement a format() method that will receive a ParameterBag containing all found tracking parameters from the request.
And it will need to return a key/value array of all formatted parameters to append to the url.
Those services also have to be tagged as exs_tracking.parameter_formatter.
See EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\CmpTrackingParameterFormatter for an example of formatter.
By convention formatter service's name is exs_tracking.xxxsomethingxxx_formatter.
Example :
1. Create the formatter class that implements EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterFormatterInterface
<?php namespace My\SomeBundle\Service; use Symfony\Component\HttpFoundation\ParameterBag; use EXS\LanderTrackingHouseBundle\Service\TrackingParameterManager\TrackingParameterFormatterInterface; class FooFormatter implements TrackingParameterFormatterInterface { public function format(ParameterBag $trackingParameters) { return [ 'foo' => $trackingParameters->get('foo'), ]; } }
2. Declare the service with tag exs_tracking.parameter_formatter
services: exs_tracking.foo_formatter: class: 'My\SomeBundle\Service\FooFormatter' tags: - { name: 'exs_tracking.parameter_formatter' }
3. Usage
As seen before, je just now need to use the Twig filter appendParameter on any url and the foo parameter will be added if defined.
<a href="{{ 'http://www.test.tld/' | appendParameter('foo') }}">Some link</a> <!-- or --> <a href="{{ 'http://www.test.tld/?foo={foo}' | appendParameter}}">Some link</a>