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 | ||
| 45 | class RaListingProjector extends Projector | ||
| 46 | { | ||
| 47 | /** | ||
| 48 | * @var RaListingRepository | ||
| 49 | */ | ||
| 50 | private $raListingRepository; | ||
| 51 | |||
| 52 | /** | ||
| 53 | * @var IdentityRepository | ||
| 54 | */ | ||
| 55 | private $identityRepository; | ||
| 56 | |||
| 57 | public function __construct(RaListingRepository $raListingRepository, IdentityRepository $identityRepository) | ||
| 62 | |||
| 63 | /** | ||
| 64 | * @param IdentityAccreditedAsRaForInstitutionEvent $event | ||
| 65 | * @return void | ||
| 66 | */ | ||
| 67 | View Code Duplication | public function applyIdentityAccreditedAsRaForInstitutionEvent(IdentityAccreditedAsRaForInstitutionEvent $event) | |
| 84 | |||
| 85 | /** | ||
| 86 | * @param IdentityAccreditedAsRaaForInstitutionEvent $event | ||
| 87 | * @return void | ||
| 88 | */ | ||
| 89 | View Code Duplication | public function applyIdentityAccreditedAsRaaForInstitutionEvent(IdentityAccreditedAsRaaForInstitutionEvent $event) | |
| 106 | |||
| 107 | public function applyRegistrationAuthorityInformationAmendedForInstitutionEvent( | ||
| 108 | RegistrationAuthorityInformationAmendedForInstitutionEvent $event | ||
| 109 |     ) { | ||
| 110 | /** @var RaListing $raListing */ | ||
| 111 | $raListing = $this->raListingRepository->findByIdentityIdAndRaInstitution($event->identityId, $event->raInstitution); | ||
| 112 | |||
| 113 |         if (!$raListing) { | ||
| 114 | throw new RuntimeException( | ||
| 115 | "Tried to amend an RaListing's registration authority location and contact information, " . | ||
| 116 | "but the listing could not be found" | ||
| 117 | ); | ||
| 118 | } | ||
| 119 | |||
| 120 | $raListing->location = $event->location; | ||
| 121 | $raListing->contactInformation = $event->contactInformation; | ||
| 122 | |||
| 123 | $this->raListingRepository->save($raListing); | ||
| 124 | } | ||
| 125 | |||
| 126 | public function applyAppointedAsRaForInstitutionEvent(AppointedAsRaForInstitutionEvent $event) | ||
| 127 |     { | ||
| 128 | /** @var RaListing $raListing */ | ||
| 129 | $raListing = $this->raListingRepository->findByIdentityIdAndRaInstitution($event->identityId, $event->raInstitution); | ||
| 130 | |||
| 131 | $raListing->role = AuthorityRole::ra(); | ||
| 132 | |||
| 133 | $this->raListingRepository->save($raListing); | ||
| 134 | } | ||
| 135 | |||
| 136 | public function applyAppointedAsRaaForInstitutionEvent(AppointedAsRaaForInstitutionEvent $event) | ||
| 137 |     { | ||
| 138 | /** @var RaListing $raListing */ | ||
| 139 | $raListing = $this->raListingRepository->findByIdentityIdAndRaInstitution($event->identityId, $event->raInstitution); | ||
| 140 | |||
| 141 | $raListing->role = AuthorityRole::raa(); | ||
| 142 | |||
| 143 | $this->raListingRepository->save($raListing); | ||
| 144 | } | ||
| 145 | |||
| 146 | public function applyRegistrationAuthorityRetractedForInstitutionEvent(RegistrationAuthorityRetractedForInstitutionEvent $event) | ||
| 150 | |||
| 151 | |||
| 152 | protected function applyIdentityForgottenEvent(IdentityForgottenEvent $event) | ||
| 156 | |||
| 157 | /** | ||
| 158 | * This method is kept to be backwards compatible for changes before FGA | ||
| 159 | * | ||
| 160 | * @param IdentityAccreditedAsRaEvent $event | ||
| 161 | * @return void | ||
| 162 | */ | ||
| 163 | View Code Duplication | public function applyIdentityAccreditedAsRaEvent(IdentityAccreditedAsRaEvent $event) | |
| 180 | |||
| 181 | /** | ||
| 182 | * This method is kept to be backwards compatible for changes before FGA | ||
| 183 | * | ||
| 184 | * @param IdentityAccreditedAsRaaEvent $event | ||
| 185 | * @return void | ||
| 186 | */ | ||
| 187 | View Code Duplication | public function applyIdentityAccreditedAsRaaEvent(IdentityAccreditedAsRaaEvent $event) | |
| 204 | |||
| 205 | /** | ||
| 206 | * This method is kept to be backwards compatible for changes before FGA | ||
| 207 | * | ||
| 208 | * @param RegistrationAuthorityInformationAmendedEvent $event | ||
| 209 | */ | ||
| 210 | public function applyRegistrationAuthorityInformationAmendedEvent( | ||
| 211 | RegistrationAuthorityInformationAmendedEvent $event | ||
| 212 |     ) { | ||
| 213 | /** @var RaListing $raListing */ | ||
| 214 | $raListing = $this->raListingRepository->findByIdentityIdAndInstitution($event->identityId, $event->identityInstitution); | ||
| 215 | |||
| 216 |         if (!$raListing) { | ||
| 217 | throw new RuntimeException( | ||
| 218 | "Tried to amend an RaListing's registration authority location and contact information, " . | ||
| 219 | "but the listing could not be found" | ||
| 220 | ); | ||
| 221 | } | ||
| 222 | |||
| 223 | $raListing->location = $event->location; | ||
| 224 | $raListing->contactInformation = $event->contactInformation; | ||
| 225 | |||
| 226 | $this->raListingRepository->save($raListing); | ||
| 227 | } | ||
| 228 | |||
| 229 | /** | ||
| 230 | * This method is kept to be backwards compatible for changes before FGA | ||
| 231 | * | ||
| 232 | * @param AppointedAsRaEvent $event | ||
| 233 | */ | ||
| 234 | public function applyAppointedAsRaEvent(AppointedAsRaEvent $event) | ||
| 243 | |||
| 244 | /** | ||
| 245 | * This method is kept to be backwards compatible for changes before FGA | ||
| 246 | * | ||
| 247 | * @param AppointedAsRaaEvent $event | ||
| 248 | */ | ||
| 249 | public function applyAppointedAsRaaEvent(AppointedAsRaaEvent $event) | ||
| 258 | |||
| 259 | /** | ||
| 260 | * This method is kept to be backwards compatible for changes before FGA | ||
| 261 | * | ||
| 262 | * @param RegistrationAuthorityRetractedEvent $event | ||
| 263 | */ | ||
| 264 | public function applyRegistrationAuthorityRetractedEvent(RegistrationAuthorityRetractedEvent $event) | ||
| 268 | } | ||
| 269 | 
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.