Advertising.php
125 lines
| 1 | <?php |
| 2 | /** |
| 3 | * Piwik - free/libre analytics platform |
| 4 | * |
| 5 | * @link https://matomo.org |
| 6 | * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later |
| 7 | */ |
| 8 | namespace Piwik\ProfessionalServices; |
| 9 | |
| 10 | use Piwik\Plugin; |
| 11 | use Piwik\Config; |
| 12 | |
| 13 | /** |
| 14 | * Advertising for providers of Professional Support for Piwik. |
| 15 | * |
| 16 | * Lets you for example check whether advertising is enabled, generate links for different landing pages etc. |
| 17 | * |
| 18 | * @since 2.16.0 |
| 19 | */ |
| 20 | class Advertising |
| 21 | { |
| 22 | const CAMPAIGN_NAME_PROFESSIONAL_SERVICES = 'App_ProfessionalServices'; |
| 23 | |
| 24 | /** |
| 25 | * @var Plugin\Manager |
| 26 | */ |
| 27 | private $pluginManager; |
| 28 | |
| 29 | /** |
| 30 | * @var Config |
| 31 | */ |
| 32 | private $config; |
| 33 | |
| 34 | public function __construct(Plugin\Manager $pluginManager, Config $config) |
| 35 | { |
| 36 | $this->pluginManager = $pluginManager; |
| 37 | $this->config = $config; |
| 38 | } |
| 39 | |
| 40 | /** |
| 41 | * Returns true if it is ok to show some advertising in the Piwik UI. |
| 42 | * @return bool |
| 43 | */ |
| 44 | public function areAdsForProfessionalServicesEnabled() |
| 45 | { |
| 46 | return self::isAdsEnabledInConfig($this->config->General); |
| 47 | } |
| 48 | |
| 49 | /** |
| 50 | * Get URL for promoting Professional Services for Piwik |
| 51 | * |
| 52 | * @param string $campaignMedium |
| 53 | * @param string $campaignContent |
| 54 | * @return string |
| 55 | */ |
| 56 | public function getPromoUrlForProfessionalServices($campaignMedium, $campaignContent = '') |
| 57 | { |
| 58 | $url = 'https://matomo.org/support-plans/?'; |
| 59 | |
| 60 | $campaign = $this->getCampaignParametersForPromoUrl( |
| 61 | $name = self::CAMPAIGN_NAME_PROFESSIONAL_SERVICES, |
| 62 | $campaignMedium, |
| 63 | $campaignContent |
| 64 | ); |
| 65 | |
| 66 | return $url . $campaign; |
| 67 | } |
| 68 | |
| 69 | /** |
| 70 | * Appends campaign parameters to the given URL for promoting any Professional Support for Piwik service. |
| 71 | * |
| 72 | * @param string $url |
| 73 | * @param string $campaignName |
| 74 | * @param string $campaignMedium |
| 75 | * @param string $campaignContent |
| 76 | * @return string |
| 77 | */ |
| 78 | public function addPromoCampaignParametersToUrl($url, $campaignName, $campaignMedium, $campaignContent = '') |
| 79 | { |
| 80 | if (empty($url)) { |
| 81 | return ''; |
| 82 | } |
| 83 | |
| 84 | if (strpos($url, '?') === false) { |
| 85 | $url .= '?'; |
| 86 | } else { |
| 87 | $url .= '&'; |
| 88 | } |
| 89 | |
| 90 | $url .= $this->getCampaignParametersForPromoUrl($campaignName, $campaignMedium, $campaignContent); |
| 91 | |
| 92 | return $url; |
| 93 | } |
| 94 | |
| 95 | /** |
| 96 | * Generates campaign URL parameters that can be used with promoting Professional Support service. |
| 97 | * |
| 98 | * @param string $campaignName |
| 99 | * @param string $campaignMedium |
| 100 | * @param string $campaignContent Optional |
| 101 | * @return string URL parameters without a leading ? or & |
| 102 | */ |
| 103 | private function getCampaignParametersForPromoUrl($campaignName, $campaignMedium, $campaignContent = '') |
| 104 | { |
| 105 | $campaignName = sprintf('pk_campaign=%s&pk_medium=%s&pk_source=Matomo_App', $campaignName, $campaignMedium); |
| 106 | |
| 107 | if (!empty($campaignContent)) { |
| 108 | $campaignName .= '&pk_content=' . $campaignContent; |
| 109 | } |
| 110 | |
| 111 | return $campaignName; |
| 112 | } |
| 113 | |
| 114 | /** |
| 115 | * @param $configGeneralSection |
| 116 | * @return bool |
| 117 | */ |
| 118 | public static function isAdsEnabledInConfig($configGeneralSection) |
| 119 | { |
| 120 | $oldSettingValue = @$configGeneralSection['piwik_pro_ads_enabled']; |
| 121 | $newSettingValue = @$configGeneralSection['piwik_professional_support_ads_enabled']; |
| 122 | return (bool) ($newSettingValue || $oldSettingValue); |
| 123 | } |
| 124 | } |
| 125 |