summaryrefslogtreecommitdiffstats
path: root/rlz/mac/lib/machine_id_mac.cc
diff options
context:
space:
mode:
authorzysxqn@google.com <zysxqn@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2012-06-26 00:28:46 +0000
committerzysxqn@google.com <zysxqn@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2012-06-26 00:28:46 +0000
commit5eff57ede25d7fe51c3bb964aaba2745e3fb1896 (patch)
treef8cb338f8e22ce99a77903d4214dfda581857e38 /rlz/mac/lib/machine_id_mac.cc
parent2be6abf3a4fb590a1b59586858d1e49ea61f0708 (diff)
downloadchromium_src-5eff57ede25d7fe51c3bb964aaba2745e3fb1896.zip
chromium_src-5eff57ede25d7fe51c3bb964aaba2745e3fb1896.tar.gz
chromium_src-5eff57ede25d7fe51c3bb964aaba2745e3fb1896.tar.bz2
Add a regenerate button to regenerate the password in Windows.
BUG=120480 TEST=Not tested. Review URL: https://chromiumcodereview.appspot.com/10642009 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@144071 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'rlz/mac/lib/machine_id_mac.cc')
-rw-r--r--rlz/mac/lib/machine_id_mac.cc147
1 files changed, 0 insertions, 147 deletions
diff --git a/rlz/mac/lib/machine_id_mac.cc b/rlz/mac/lib/machine_id_mac.cc
deleted file mode 100644
index 2198978..0000000
--- 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