diff --git a/includes/uuid.inc b/includes/uuid.inc
new file mode 100644
index 0000000..ec9ec9f
--- /dev/null
+++ b/includes/uuid.inc
@@ -0,0 +1,90 @@
+<?php
+
+/**
+ * @file
+ * Handling of universally unique identifiers.
+ */
+
+/**
+ * Class responsible for generating and validtaing universally unique
+ * identifiers.
+ */
+class Uuid {
+
+  /**
+   * Generates an universally unique identifier.
+   *
+   * This function first checks for the PECL alternative for generating
+   * universally unique identifiers. If that doesn't exist, then it falls back on
+   * PHP for generating that.
+   *
+   * @return
+   *   An UUID, made up of 32 hex digits and 4 hyphens.
+   */
+  public function generate() {
+    // Debian/Ubuntu ships with the OSSP implementation for UUID. This conflicts
+    // with PECL functions.
+    if (function_exists('uuid_create') && !function_exists('uuid_make')) {
+      return $this->generatePecl();
+    }
+    // Try to use the COM implementation for Windows users.
+    elseif (function_exists('com_create_guid')) {
+      return $this->generateCom();
+    }
+    else {
+      return $this->generatePhp();
+    }
+  }
+
+  /**
+   * Check that a string appears to be in the format of a UUID.
+   *
+   * @param $uuid
+   *  The string to test.
+   *
+   * @return
+   *   TRUE if the string is well formed.
+   */
+  public function isValid($uuid) {
+    return preg_match("/^[0-9a-f]{8}-([0-9a-f]{4}-){3}[0-9a-f]{12}$/", $uuid);
+  }
+
+  /**
+   * Generates a UUID using the PECL extension.
+   */
+  protected function generatePecl() {
+    return uuid_create(UUID_TYPE_DEFAULT);
+  }
+
+  /**
+   * Generates a UUID using the Windows internal GUID generator.
+   *
+   * @see http://php.net/com_create_guid
+   */
+  protected function generateCom() {
+    // Remove {} wrapper and make lower case to keep result consistent.
+    return drupal_strtolower(trim(com_create_guid(), '{}'));
+  }
+
+  /**
+   * Generates a UUID v4 using PHP code.
+   *
+   * @see http://php.net/uniqid#65879
+   */
+  protected function generatePhp() {
+    // The field names refer to RFC 4122 section 4.1.2.
+    return sprintf('%04x%04x-%04x-%03x4-%04x-%04x%04x%04x',
+      // 32 bits for "time_low".
+      mt_rand(0, 65535), mt_rand(0, 65535),
+      // 16 bits for "time_mid".
+      mt_rand(0, 65535),
+      // 12 bits before the 0100 of (version) 4 for "time_hi_and_version".
+      mt_rand(0, 4095),
+      bindec(substr_replace(sprintf('%016b', mt_rand(0, 65535)), '01', 6, 2)),
+      // 8 bits, the last two of which (positions 6 and 7) are 01, for "clk_seq_hi_res"
+      // (hence, the 2nd hex digit after the 3rd hyphen can only be 1, 5, 9 or d)
+      // 8 bits for "clk_seq_low" 48 bits for "node".
+      mt_rand(0, 65535), mt_rand(0, 65535), mt_rand(0, 65535)
+    );
+  }
+}
diff --git a/modules/system/system.test b/modules/system/system.test
index 9944619..0e293bc 100644
--- a/modules/system/system.test
+++ b/modules/system/system.test
@@ -2466,3 +2466,43 @@ class SystemIndexPhpTest extends DrupalWebTestCase {
   }
 }
 
+/**
+ * Tests uuid.inc and related functions.
+ */
+class UuidTestCase extends DrupalWebTestCase {
+  public static function getInfo() {
+    return array(
+      'name' => 'UUID handling',
+      'description' => "Test the handling of universally unique identifiers.",
+      'group' => 'System',
+    );
+  }
+
+  /**
+   * Test UUID handling.
+   */
+  function testUuidHandling() {
+    // Initiate the generator. This will lazy-load uuid.inc.
+    $uuid = new Uuid();
+
+    // This is a valid UUID, we know that.
+    $valid_uuid = '0ab26e6b-f074-4e44-9da6-1205fa0e9761';
+    $invalid_uuid1 = '0ab26e6b-f074-4e44-9da6-1205fa0e976';
+    $invalid_uuid2 = '0ab26e6b-f074-4e44-9da-1205fa0e9761';
+    // Test the uuid_is_valid() function.
+    $test = (
+      $uuid->isValid($valid_uuid)
+      && !$uuid->isValid($invalid_uuid1)
+      && !$uuid->isValid($invalid_uuid2)
+    );
+    $this->assertTrue($test, 'UUID validation works.');
+
+    // Test generating a UUID.
+    $uuid1 = $uuid->generate();
+    $this->assertTrue($uuid->isValid($uuid1), 'UUID generation works.');
+
+    // Just to demonstrate the purpose of the UUID functionality.
+    $uuid2 = $uuid->generate();
+    $this->assertNotEqual($uuid1, $uuid2, 'Same UUID was not generated twice.');
+  }
+}
