From 4c3b3764c23027873f0935f65375e18ce8fda65a Mon Sep 17 00:00:00 2001
From: Nathaniel Catchpole <catch@35733.no-reply.drupal.org>
Date: Thu, 28 Apr 2016 11:45:17 +0100
Subject: [PATCH] Issue #2708379 by alexpott: Add uuid service to
 core.services.yml

---
 core/core.services.yml                       |  3 ++-
 core/lib/Drupal/Core/CoreServiceProvider.php | 21 +++++++-------------
 2 files changed, 9 insertions(+), 15 deletions(-)

diff --git a/core/core.services.yml b/core/core.services.yml
index 5877a38c10aa..6049d3b208e4 100644
--- a/core/core.services.yml
+++ b/core/core.services.yml
@@ -1600,7 +1600,8 @@ services:
   update.post_update_registry_factory:
     class: Drupal\Core\Update\UpdateRegistryFactory
     parent: container.trait
-
+  uuid:
+    class: Drupal\Component\Uuid\Php
   response_filter.active_link:
     class: Drupal\Core\EventSubscriber\ActiveLinkResponseFilter
     arguments: ['@current_user', '@path.current', '@path.matcher', '@language_manager']
diff --git a/core/lib/Drupal/Core/CoreServiceProvider.php b/core/lib/Drupal/Core/CoreServiceProvider.php
index 0b6ce5264f26..51b1c5103ff9 100644
--- a/core/lib/Drupal/Core/CoreServiceProvider.php
+++ b/core/lib/Drupal/Core/CoreServiceProvider.php
@@ -15,6 +15,7 @@
 use Drupal\Core\DependencyInjection\Compiler\StackedSessionHandlerPass;
 use Drupal\Core\DependencyInjection\Compiler\RegisterStreamWrappersPass;
 use Drupal\Core\DependencyInjection\Compiler\TwigExtensionPass;
+use Drupal\Core\DependencyInjection\ServiceModifierInterface;
 use Drupal\Core\DependencyInjection\ServiceProviderInterface;
 use Drupal\Core\DependencyInjection\ContainerBuilder;
 use Drupal\Core\DependencyInjection\Compiler\ModifyServiceDefinitionsPass;
@@ -39,13 +40,12 @@
  *
  * @ingroup container
  */
-class CoreServiceProvider implements ServiceProviderInterface  {
+class CoreServiceProvider implements ServiceProviderInterface, ServiceModifierInterface  {
 
   /**
    * {@inheritdoc}
    */
   public function register(ContainerBuilder $container) {
-    $this->registerUuid($container);
     $this->registerTest($container);
 
     // Only register the private file stream wrapper if a file path has been set.
@@ -98,30 +98,23 @@ public function register(ContainerBuilder $container) {
   }
 
   /**
-   * Determines and registers the UUID service.
+   * Alters the UUID service to use the most efficient method available.
    *
    * @param \Drupal\Core\DependencyInjection\ContainerBuilder $container
    *   The container builder.
-   *
-   * @return string
-   *   Class name for the UUID service.
    */
-  public static function registerUuid(ContainerBuilder $container) {
-    $uuid_class = 'Drupal\Component\Uuid\Php';
-
+  public function alter(ContainerBuilder $container) {
+    $uuid_service = $container->getDefinition('uuid');
     // Debian/Ubuntu uses the (broken) OSSP extension as their UUID
     // implementation. The OSSP implementation is not compatible with the
     // PECL functions.
     if (function_exists('uuid_create') && !function_exists('uuid_make')) {
-      $uuid_class = 'Drupal\Component\Uuid\Pecl';
+      $uuid_service->setClass('Drupal\Component\Uuid\Pecl');
     }
     // Try to use the COM implementation for Windows users.
     elseif (function_exists('com_create_guid')) {
-      $uuid_class = 'Drupal\Component\Uuid\Com';
+      $uuid_service->setClass('Drupal\Component\Uuid\Com');
     }
-
-    $container->register('uuid', $uuid_class);
-    return $uuid_class;
   }
 
   /**
-- 
GitLab