Index: rlz/mac/lib/machine_id_mac.cc |
diff --git a/rlz/mac/lib/machine_id_mac.cc b/rlz/mac/lib/machine_id_mac.cc |
deleted file mode 100644 |
index 2198978a29740beebd6289aa3071cbdd57591524..0000000000000000000000000000000000000000 |
--- a/rlz/mac/lib/machine_id_mac.cc |
+++ /dev/null |
@@ -1,147 +0,0 @@ |
-// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
- |
-#include <CoreFoundation/CoreFoundation.h> |
-#include <IOKit/IOKitLib.h> |
-#include <IOKit/network/IOEthernetInterface.h> |
-#include <IOKit/network/IONetworkInterface.h> |
-#include <IOKit/network/IOEthernetController.h> |
- |
-#include "base/logging.h" |
-#include "base/mac/foundation_util.h" |
-#include "base/mac/scoped_cftyperef.h" |
-#include "base/mac/scoped_ioobject.h" |
-#include "base/string16.h" |
-#include "base/stringprintf.h" |
-#include "base/sys_string_conversions.h" |
-#include "base/utf_string_conversions.h" |
- |
-namespace rlz_lib { |
- |
-namespace { |
- |
-// See http://developer.apple.com/library/mac/#technotes/tn1103/_index.html |
- |
-// The caller is responsible for freeing |matching_services|. |
-bool FindEthernetInterfaces(io_iterator_t* matching_services) { |
- base::mac::ScopedCFTypeRef<CFMutableDictionaryRef> matching_dict( |
- IOServiceMatching(kIOEthernetInterfaceClass)); |
- if (!matching_dict) |
- return false; |
- |
- base::mac::ScopedCFTypeRef<CFMutableDictionaryRef> primary_interface( |
- CFDictionaryCreateMutable(kCFAllocatorDefault, 0, |
- &kCFTypeDictionaryKeyCallBacks, |
- &kCFTypeDictionaryValueCallBacks)); |
- if (!primary_interface) |
- return false; |
- |
- CFDictionarySetValue( |
- primary_interface, CFSTR(kIOPrimaryInterface), kCFBooleanTrue); |
- CFDictionarySetValue( |
- matching_dict, CFSTR(kIOPropertyMatchKey), primary_interface); |
- |
- kern_return_t kern_result = IOServiceGetMatchingServices( |
- kIOMasterPortDefault, matching_dict.release(), matching_services); |
- |
- return kern_result == KERN_SUCCESS; |
-} |
- |
-bool GetMACAddressFromIterator(io_iterator_t primary_interface_iterator, |
- uint8_t* buffer, size_t buffer_size) { |
- if (buffer_size < kIOEthernetAddressSize) |
- return false; |
- |
- bool success = false; |
- |
- bzero(buffer, buffer_size); |
- base::mac::ScopedIOObject<io_object_t> primary_interface; |
- while (primary_interface.reset(IOIteratorNext(primary_interface_iterator)), |
- primary_interface) { |
- io_object_t primary_interface_parent; |
- kern_return_t kern_result = IORegistryEntryGetParentEntry( |
- primary_interface, kIOServicePlane, &primary_interface_parent); |
- base::mac::ScopedIOObject<io_object_t> primary_interface_parent_deleter( |
- primary_interface_parent); |
- success = kern_result == KERN_SUCCESS; |
- |
- if (!success) |
- continue; |
- |
- base::mac::ScopedCFTypeRef<CFTypeRef> mac_data( |
- IORegistryEntryCreateCFProperty(primary_interface_parent, |
- CFSTR(kIOMACAddress), |
- kCFAllocatorDefault, |
- 0)); |
- CFDataRef mac_data_data = base::mac::CFCast<CFDataRef>(mac_data); |
- if (mac_data_data) { |
- CFDataGetBytes( |
- mac_data_data, CFRangeMake(0, kIOEthernetAddressSize), buffer); |
- } |
- } |
- |
- return success; |
-} |
- |
-bool GetMacAddress(unsigned char* buffer, size_t size) { |
- io_iterator_t primary_interface_iterator; |
- if (!FindEthernetInterfaces(&primary_interface_iterator)) |
- return false; |
- bool result = GetMACAddressFromIterator( |
- primary_interface_iterator, buffer, size); |
- IOObjectRelease(primary_interface_iterator); |
- return result; |
-} |
- |
-CFStringRef CopySerialNumber() { |
- base::mac::ScopedIOObject<io_service_t> expert_device( |
- IOServiceGetMatchingService(kIOMasterPortDefault, |
- IOServiceMatching("IOPlatformExpertDevice"))); |
- if (!expert_device) |
- return NULL; |
- |
- base::mac::ScopedCFTypeRef<CFTypeRef> serial_number( |
- IORegistryEntryCreateCFProperty(expert_device, |
- CFSTR(kIOPlatformSerialNumberKey), |
- kCFAllocatorDefault, |
- 0)); |
- CFStringRef serial_number_cfstring = |
- base::mac::CFCast<CFStringRef>(serial_number); |
- if (!serial_number_cfstring) |
- return NULL; |
- |
- ignore_result(serial_number.release()); |
- return serial_number_cfstring; |
-} |
- |
-} // namespace |
- |
-bool GetRawMachineId(string16* data, int* more_data) { |
- uint8_t mac_address[kIOEthernetAddressSize]; |
- |
- data->clear(); |
- if (GetMacAddress(mac_address, sizeof(mac_address))) { |
- *data += ASCIIToUTF16(StringPrintf("mac:%02x%02x%02x%02x%02x%02x", |
- mac_address[0], mac_address[1], mac_address[2], |
- mac_address[3], mac_address[4], mac_address[5])); |
- } |
- |
- // A MAC address is enough to uniquely identify a machine, but it's only 6 |
- // bytes, 3 of which are manufacturer-determined. To make brute-forcing the |
- // SHA1 of this harder, also append the system's serial number. |
- CFStringRef serial = CopySerialNumber(); |
- if (serial) { |
- if (!data->empty()) |
- *data += UTF8ToUTF16(" "); |
- *data += UTF8ToUTF16("serial:") + base::SysCFStringRefToUTF16(serial); |
- CFRelease(serial); |
- } |
- |
- // On windows, this is set to the volume id. Since it's not scrambled before |
- // being sent, just set it to 1. |
- *more_data = 1; |
- return true; |
-} |
- |
-} // namespace rlz_lib |