Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1675)

Unified Diff: base/ios/device_util.mm

Issue 1647803004: Move base to DEPS (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « base/ios/device_util.h ('k') | base/ios/device_util_unittest.mm » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: base/ios/device_util.mm
diff --git a/base/ios/device_util.mm b/base/ios/device_util.mm
deleted file mode 100644
index 4af8234988fc35b3f82fb72ef633f380a3ca43b0..0000000000000000000000000000000000000000
--- a/base/ios/device_util.mm
+++ /dev/null
@@ -1,177 +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 "base/ios/device_util.h"
-
-#include <CommonCrypto/CommonDigest.h>
-#import <UIKit/UIKit.h>
-
-#include <ifaddrs.h>
-#include <net/if_dl.h>
-#include <string.h>
-#include <sys/socket.h>
-#include <sys/sysctl.h>
-
-#include "base/logging.h"
-#include "base/mac/scoped_cftyperef.h"
-#include "base/memory/scoped_ptr.h"
-#include "base/strings/string_util.h"
-#include "base/strings/stringprintf.h"
-#include "base/strings/sys_string_conversions.h"
-
-namespace {
-
-// Client ID key in the user preferences.
-NSString* const kLegacyClientIdPreferenceKey = @"ChromiumClientID";
-NSString* const kClientIdPreferenceKey = @"ChromeClientID";
-// Current hardware type. This is used to detect that a device has been backed
-// up and restored to another device, and allows regenerating a new device id.
-NSString* const kHardwareTypePreferenceKey = @"ClientIDGenerationHardwareType";
-// Default salt for device ids.
-const char kDefaultSalt[] = "Salt";
-// Zero UUID returned on buggy iOS devices.
-NSString* const kZeroUUID = @"00000000-0000-0000-0000-000000000000";
-
-NSString* GenerateClientId() {
- NSUserDefaults* defaults = [NSUserDefaults standardUserDefaults];
-
- // Try to migrate from legacy client id.
- NSString* client_id = [defaults stringForKey:kLegacyClientIdPreferenceKey];
-
- // Some iOS6 devices return a buggy identifierForVendor:
- // http://openradar.appspot.com/12377282. If this is the case, revert to
- // generating a new one.
- if (!client_id || [client_id isEqualToString:kZeroUUID]) {
- client_id = [[[UIDevice currentDevice] identifierForVendor] UUIDString];
- if ([client_id isEqualToString:kZeroUUID])
- client_id = base::SysUTF8ToNSString(ios::device_util::GetRandomId());
- }
- return client_id;
-}
-
-} // namespace
-
-namespace ios {
-namespace device_util {
-
-std::string GetPlatform() {
- std::string platform;
- size_t size = 0;
- sysctlbyname("hw.machine", NULL, &size, NULL, 0);
- sysctlbyname("hw.machine", base::WriteInto(&platform, size), &size, NULL, 0);
- return platform;
-}
-
-bool RamIsAtLeast512Mb() {
- // 512MB devices report anywhere from 502-504 MB, use 450 MB just to be safe.
- return RamIsAtLeast(450);
-}
-
-bool RamIsAtLeast1024Mb() {
- // 1GB devices report anywhere from 975-999 MB, use 900 MB just to be safe.
- return RamIsAtLeast(900);
-}
-
-bool RamIsAtLeast(uint64_t ram_in_mb) {
- uint64_t memory_size = 0;
- size_t size = sizeof(memory_size);
- if (sysctlbyname("hw.memsize", &memory_size, &size, NULL, 0) == 0) {
- // Anything >= 500M, call high ram.
- return memory_size >= ram_in_mb * 1024 * 1024;
- }
- return false;
-}
-
-bool IsSingleCoreDevice() {
- uint64_t cpu_number = 0;
- size_t sizes = sizeof(cpu_number);
- sysctlbyname("hw.physicalcpu", &cpu_number, &sizes, NULL, 0);
- return cpu_number == 1;
-}
-
-std::string GetMacAddress(const std::string& interface_name) {
- std::string mac_string;
- struct ifaddrs* addresses;
- if (getifaddrs(&addresses) == 0) {
- for (struct ifaddrs* address = addresses; address;
- address = address->ifa_next) {
- if ((address->ifa_addr->sa_family == AF_LINK) &&
- strcmp(interface_name.c_str(), address->ifa_name) == 0) {
- const struct sockaddr_dl* found_address_struct =
- reinterpret_cast<const struct sockaddr_dl*>(address->ifa_addr);
-
- // |found_address_struct->sdl_data| contains the interface name followed
- // by the interface address. The address part can be accessed based on
- // the length of the name, that is, |found_address_struct->sdl_nlen|.
- const unsigned char* found_address =
- reinterpret_cast<const unsigned char*>(
- &found_address_struct->sdl_data[
- found_address_struct->sdl_nlen]);
-
- int found_address_length = found_address_struct->sdl_alen;
- for (int i = 0; i < found_address_length; ++i) {
- if (i != 0)
- mac_string.push_back(':');
- base::StringAppendF(&mac_string, "%02X", found_address[i]);
- }
- break;
- }
- }
- freeifaddrs(addresses);
- }
- return mac_string;
-}
-
-std::string GetRandomId() {
- base::ScopedCFTypeRef<CFUUIDRef> uuid_object(
- CFUUIDCreate(kCFAllocatorDefault));
- base::ScopedCFTypeRef<CFStringRef> uuid_string(
- CFUUIDCreateString(kCFAllocatorDefault, uuid_object));
- return base::SysCFStringRefToUTF8(uuid_string);
-}
-
-std::string GetDeviceIdentifier(const char* salt) {
- NSUserDefaults* defaults = [NSUserDefaults standardUserDefaults];
-
- NSString* last_seen_hardware =
- [defaults stringForKey:kHardwareTypePreferenceKey];
- NSString* current_hardware = base::SysUTF8ToNSString(GetPlatform());
- if (!last_seen_hardware) {
- last_seen_hardware = current_hardware;
- [defaults setObject:current_hardware forKey:kHardwareTypePreferenceKey];
- [defaults synchronize];
- }
-
- NSString* client_id = [defaults stringForKey:kClientIdPreferenceKey];
-
- if (!client_id || ![last_seen_hardware isEqualToString:current_hardware]) {
- client_id = GenerateClientId();
- [defaults setObject:client_id forKey:kClientIdPreferenceKey];
- [defaults setObject:current_hardware forKey:kHardwareTypePreferenceKey];
- [defaults synchronize];
- }
-
- return GetSaltedString(base::SysNSStringToUTF8(client_id),
- salt ? salt : kDefaultSalt);
-}
-
-std::string GetSaltedString(const std::string& in_string,
- const std::string& salt) {
- DCHECK(salt.length());
- NSData* hash_data = [base::SysUTF8ToNSString(in_string + salt)
- dataUsingEncoding:NSUTF8StringEncoding];
-
- unsigned char hash[CC_SHA256_DIGEST_LENGTH];
- CC_SHA256([hash_data bytes], [hash_data length], hash);
- CFUUIDBytes* uuid_bytes = reinterpret_cast<CFUUIDBytes*>(hash);
-
- base::ScopedCFTypeRef<CFUUIDRef> uuid_object(
- CFUUIDCreateFromUUIDBytes(kCFAllocatorDefault, *uuid_bytes));
- base::ScopedCFTypeRef<CFStringRef> device_id(
- CFUUIDCreateString(kCFAllocatorDefault, uuid_object));
- return base::SysCFStringRefToUTF8(device_id);
-}
-
-} // namespace device_util
-} // namespace ios
« no previous file with comments | « base/ios/device_util.h ('k') | base/ios/device_util_unittest.mm » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698