From 3072f841ab96369546a6ddb7d0b5d14d84db2c0b Mon Sep 17 00:00:00 2001
From: Alex Pott <alex.a.pott@googlemail.com>
Date: Sat, 2 Nov 2019 07:51:59 +0100
Subject: [PATCH] Issue #3088403 by Mile23, Mixologic: Defensive coding: Vendor
 hardening plugin sometimes receives AliasPackage

---
 .../VendorHardening/VendorHardeningPlugin.php    | 16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)

diff --git a/composer/Plugin/VendorHardening/VendorHardeningPlugin.php b/composer/Plugin/VendorHardening/VendorHardeningPlugin.php
index 71410c4dd6dd..373b0654c8cb 100644
--- a/composer/Plugin/VendorHardening/VendorHardeningPlugin.php
+++ b/composer/Plugin/VendorHardening/VendorHardeningPlugin.php
@@ -7,7 +7,7 @@
 use Composer\Installer\PackageEvent;
 use Composer\Installer\PackageEvents;
 use Composer\IO\IOInterface;
-use Composer\Package\CompletePackage;
+use Composer\Package\BasePackage;
 use Composer\Plugin\PluginInterface;
 use Composer\Script\Event;
 use Composer\Script\ScriptEvents;
@@ -150,13 +150,21 @@ public function onPostPackageUpdate(PackageEvent $event) {
    * Where the configured bin files are in the directories to be removed, remove
    * the bin config.
    *
-   * @param \Composer\Package\CompletePackage $package
+   * @param \Composer\Package\BasePackage $package
    *   The package we're cleaning up.
    */
-  protected function removeBinBeforeCleanup(CompletePackage $package) {
-    // Only do this if there are binaries and cleanup paths.
+  protected function removeBinBeforeCleanup(BasePackage $package) {
+    // We can process AliasPackage and Package objects, and they share the
+    // BasePackage parent class. However, since there is no common interface for
+    // these package types that allow for the setBinaries() method, and since
+    // BasePackage does not include the setBinaries() method, we have to make
+    // sure we're processing a class with a setBinaries() method.
+    if (!method_exists($package, 'setBinaries')) {
+      return;
+    }
     $binaries = $package->getBinaries();
     $clean_paths = $this->config->getPathsForPackage($package->getName());
+    // Only do this if there are binaries and cleanup paths.
     if (!$binaries || !$clean_paths) {
       return;
     }
-- 
GitLab