Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.
Common duplication problems, and corresponding solutions are:
| 1 | <?php | ||
| 35 | class Consumerscore extends \Payone\Core\Helper\Base | ||
| 36 | { | ||
| 37 | const CONFIG_KEY_CONSUMERSCORE_SAMPLE_COUNTER = 'payone_consumerscore_sample_counter'; | ||
| 38 | |||
| 39 | /** | ||
| 40 | * Config writer resource | ||
| 41 | * | ||
| 42 | * @var \Magento\Framework\App\Config\Storage\WriterInterface | ||
| 43 | */ | ||
| 44 | protected $configWriter; | ||
| 45 | |||
| 46 | /** | ||
| 47 | * PAYONE database helper | ||
| 48 | * | ||
| 49 | * @var \Payone\Core\Helper\Database | ||
| 50 | */ | ||
| 51 | protected $databaseHelper; | ||
| 52 | |||
| 53 | /** | ||
| 54 | * Constructor | ||
| 55 | * | ||
| 56 | * @param \Magento\Framework\App\Helper\Context $context | ||
| 57 | * @param \Magento\Store\Model\StoreManagerInterface $storeManager | ||
| 58 | * @param \Payone\Core\Helper\Shop $shopHelper | ||
| 59 | * @param \Magento\Framework\App\Config\Storage\WriterInterface $configWriter | ||
| 60 | * @param \Payone\Core\Helper\Database $databaseHelper | ||
| 61 | */ | ||
| 62 | public function __construct( | ||
| 73 | |||
| 74 | /** | ||
| 75 | * Retrieve the creditrating sample counter from config | ||
| 76 | * | ||
| 77 | * @return int | ||
| 78 | */ | ||
| 79 | public function getConsumerscoreSampleCounter() | ||
| 91 | |||
| 92 | /** | ||
| 93 | * Store new value for creditrating sample counter in config | ||
| 94 | * | ||
| 95 | * @param $iCount | ||
| 96 | * @return true | ||
| 97 | */ | ||
| 98 | public function setConsumerscoreSampleCounter($iCount) | ||
| 108 | |||
| 109 | /** | ||
| 110 | * Increment creditrating sample counter in config | ||
| 111 | * | ||
| 112 | * @return int Returns the new counter value | ||
| 113 | */ | ||
| 114 | public function incrementConsumerscoreSampleCounter() | ||
| 122 | |||
| 123 | /** | ||
| 124 | * Determine if a consumerscore sample has to be taken | ||
| 125 | * | ||
| 126 | * @return bool | ||
| 127 | */ | ||
| 128 | public function isSampleNeeded() | ||
| 139 | |||
| 140 | /** | ||
| 141 | * Return if the consumerscore hint text has to be shown on payment selection | ||
| 142 | * | ||
| 143 | * @return bool | ||
| 144 | */ | ||
| 145 | View Code Duplication | public function canShowPaymentHintText() | |
| 154 | |||
| 155 | /** | ||
| 156 | * Return if the consumerscore agreement message has to be shown on payment selection | ||
| 157 | * | ||
| 158 | * @return bool | ||
| 159 | */ | ||
| 160 | View Code Duplication | public function canShowAgreementMessage() | |
| 169 | |||
| 170 | /** | ||
| 171 | * Get worst score | ||
| 172 | * | ||
| 173 | * @param array $aScores | ||
| 174 | * @return string | ||
| 175 | */ | ||
| 176 | public function getWorstScore($aScores) | ||
| 187 | |||
| 188 | /** | ||
| 189 | * Get the allowed methods for the score and transform it into an array | ||
| 190 | * | ||
| 191 | * @param string $sScore | ||
| 192 | * @return array | ||
| 193 | */ | ||
| 194 | public function getAllowedMethodsForScore($sScore) | ||
| 209 | |||
| 210 | /** | ||
| 211 | * Copy the status of old creditrating checks to the new addresses | ||
| 212 | * when the lifetime of the old check was still active | ||
| 213 | * | ||
| 214 | * @param AddressInterface $oAddress | ||
| 215 | * @return void | ||
| 216 | */ | ||
| 217 | public function copyOldStatusToNewAddress(AddressInterface $oAddress) | ||
| 224 | |||
| 225 | /** | ||
| 226 | * Determine if the given quote total needs a consumerscore check | ||
| 227 | * | ||
| 228 | * @param double $dTotal | ||
| 229 | * @return bool | ||
| 230 | */ | ||
| 231 | public function isCheckNeededForPrice($dTotal) | ||
| 240 | |||
| 241 | /** | ||
| 242 | * Base checks if a creditrating check is needed | ||
| 243 | * | ||
| 244 | * @param string $sIntegrationEvent | ||
| 245 | * @param double $dGrandTotal | ||
| 246 | * @return bool | ||
| 247 | */ | ||
| 248 | public function isCreditratingNeeded($sIntegrationEvent, $dGrandTotal) | ||
| 267 | } | ||
| 268 | 
Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.
You can also find more detailed suggestions in the “Code” section of your repository.