Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

📱 🆔  iOS UUID / Universally Unique Identifiers library as alternative to UDID and identifierForVendor.

License

NotificationsYou must be signed in to change notification settings

fabiocaccamo/FCUUID

Repository files navigation

iOSUUID library as alternative to the old goodUDID andidentifierForVendor.This library provides the simplest API to obtainuniversally unique identifiers with different levels ofpersistence.

It's possible to retrieve theUUIDs created for all devices of the same user, in this way with a little bit of server-side helpit's possible manage guest accounts across multiple devices easily.

Requirements & dependencies

  • iOS >= 5.0
  • ARC enabled
  • Key-value storage enabled(target / Capabilities / iCloud / Key-value storage)
  • Security.framework
  • UICKeyChainStore
  • (optional) - Key-value storage enabled -> Target / Capabilities / iCloud / Key-value storage enabled if you want toshareuuidsOfUserDevices valuesacross multiple devices using the same iCloud account.
  • (optional) - KeyChain sharing enabled (entitlements and provisioning profile) if you need toshare the sameuuidForDevice /uuidsOfUserDevices valuesacross multiple apps with the same bundle seed.

Installation

CocoaPods:

pod 'FCUUID'

  1. File > Swift Packages > Add Package Dependency
  2. Addhttps://github.com/fabiocaccamo/FCUUID
  3. Select "Up to Next Major" with "1.0.0"
github "fabiocaccamo/FCUUID"

Manual install:

Optional setup:

It is recommended to do the setup inapplicationDidFinishLaunchingWithOptions method.

  • Add an observer to theFCUUIDsOfUserDevicesDidChangeNotification to be notified about uuids of user devices changes.
  • If necessary,migrate from a previously used UUID or UDID using one of the migrations methods listed in the API section (it's recommended to do migration before callinguuidForDevice oruuidsForUserDevices methods). Keep in mind thatmigration works only if the existing value is a valid uuid anduuidForDevice has not been created yet.
  • Call any class method to enforce iCloud sync.

API

Get different UUIDs (each one with its own persistency level)

//changes each time (no persistent)+(NSString *)uuid;//changes each time (no persistent), but allows to keep in memory more temporary uuids+(NSString *)uuidForKey:(id<NSCopying>)key;//changes each time the app gets launched (persistent to session)+(NSString *)uuidForSession;//changes each time the app gets installed (persistent to installation)+(NSString *)uuidForInstallation;//changes each time all the apps of the same vendor are uninstalled (this works exactly as identifierForVendor)+(NSString *)uuidForVendor;//changes only on system reset, this is the best replacement to the good old udid (persistent to device)+(NSString *)uuidForDevice;//or#import"UIDevice+FCUUID.h"[[UIDevicecurrentDevice]uuid];

Get the list of UUIDs of user devices

//returns the list of all uuidForDevice of the same user, in this way it's possible manage guest accounts across multiple devices easily+(NSArray *)uuidsOfUserDevices;

Migrate from a previously stored UUID / UDIDBefore migrating an existing value it's recommended todebug it by simply passingcommitMigration:NO and logging the returned value.When you will be ready for committing the migration, usecommitMigration:YES.After the migration, any future call touuidForDevice will return the migrated value.

//these methods search for an existing UUID / UDID stored in the KeyChain or in UserDefaults for the given key / service / access-group+(NSString *)uuidForDeviceMigratingValue:(NSString *)value commitMigration:(BOOL)commitMigration;+(NSString *)uuidForDeviceMigratingValueForKey:(NSString *)key commitMigration:(BOOL)commitMigration;+(NSString *)uuidForDeviceMigratingValueForKey:(NSString *)key service:(NSString *)service commitMigration:(BOOL)commitMigration;+(NSString *)uuidForDeviceMigratingValueForKey:(NSString *)key service:(NSString *)service accessGroup:(NSString *)accessGroup commitMigration:(BOOL)commitMigration;

Check if value is a valid UUID

+(BOOL)uuidValueIsValid:(NSString *)uuidValue;

Persistence

  • yes
  • -no
  • *read notes below
PERSISTSApp memoryApp relaunchReset Advertising IdentifierApp reinstallSystem rebootSystem upgradeSystem reset
uuid-------
uuidForKey:key------
uuidForSession------
uuidForInstallation---
uuidForVendor-*--
uuidForDevice**

*(persists only if the user have not uninstalled all apps of the same vendor)

**(persists only if the user restores a device backup which includes also keychain's data)

FAQ

How can I share the device uuid between two apps?

You must haveKeyChain sharing enabled (entitlements and provisioning profile) and your apps identifiers must have the same bundle seed.

What happens if I calluuidForDevice on 2 different devices using same iCloud account and iCloud Keychain?

You will obtain 2different uuid(s), and if you calluuidsOfUserDevices you will obtain a list containing the uuids of both devices.

When I reboot / upgrade / reset my device system, will device uuid change?

Please check thepersistence table above.

Support development

Donate

License

Released underMIT License.


[8]ページ先頭

©2009-2025 Movatter.jp