Skip to content

Using your Apple device as an access card in unsupported systems

Notifications You must be signed in to change notification settings

kormax/apple-device-as-access-card

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 

Repository files navigation

Using your Apple device as an access card in unsupported systems

![Static UID demo]

Pay attention to the UID value

Overview

This repository describes general status on the topic and a possible solution to allow you to use your device as an access card in UID-based access systems (without cloning, consent on behalf of maintainer will be required).
In case you've already tried researching this topic, feel free to skip the Introduction section straight to The Solution.

Introduction

Many people have been beating their heads against the wall trying to use their Apple device as an access card.

Sadly, due to closed NFC and Wallet ecosystem, such a thing is not possibe to do on your own without any explicit support on the behalf of Apple and access system provider.
Thankfuly, as of now this market request is starting to be fulfilled by the likes of Google, Apple with cooperation of access system manufacturers and providers like HID, Brivo, Salto, WaveLynx, Nedap, Kisi, Assa Abloy, but ubiquitous support is far from reality, moreover those official solutions require manual approval, incur additional (in some cases absolutely cuckoo $$$) fees.

The search for a potential bypass had lead some people into the topics of VAS, ECP and HCE API (which actually exists in IOS, but is private, used by VAS), but those solutions don't work with existing reader infrastructures.

The solution

May be deemed more elegant than some people could expect.
It lies in one of the Chinese transit card brands, called "China T-Union", that is officially supported by Apple Wallet.

![T-Union card in wallet]

At first look there's nothing special about this card type, it has the same charachteristics as any transit card in Wallet:

  • It has a viewable balance;
  • It has configurable express mode;
  • It can be freely moved between devices.

What makes this card powerful, lies in the way it changes how NFC behaves on your device when it's set as a default transit card:

  • Your device stops randomizing the UID on each tap;
  • Your device begins responding to all NFC readers as if they were express-transit enabled, just like on Android;
  • Also this card does not change its serial number and UID when moving to other devices, unlike most other ones.

All those properties are unique to this card type and cannot be replicated with any other card type, and coincidentally they make it ideal for usage in access systems that use the UID of the card as the only means of authentication.

Now, it's time to talk about the downsides. This is a point that might break the hopes for a lot of people:

  • Thing is, UID-only authentication is deemed very unsecure, and thus is uncommon in real-life installations. Some installations allow UID auth in a fallback/compatability mode, which is more common.
  • You cannot control the UID of the card that will be generated for you, this means that you'll still need to ask permission of the system owner to add your UID into it, a chance of getting a collision would be too little and too expensive to verify.

Following systems are known to have UID-based authentication:

  • UniFi Access with the "UniFi Access Credentials Only" setting disabled;
  • [Needs expanding].

In case the stars align in your case, a next question would be how to aquire such a card. Next section tries to answer that question.

The solution for solution

China T-Union cards are quite hard to get, as if you've tried adding one straight from Wallet, you've probably encountered an error message telling you that you have to have a Chinese UnionPay card. Emphasis on Chinese, as global variants aren't accepted too.

To overcome this problem, you have to have following prerequisites:

(NOTE) Google says that many people are having issues with SMS verification, so this method might not be working now. In this case the only thing left is to wait for this issue to resolve.

If you have everything, follow the next steps:

  1. Install the AliPay app;

  2. Register inside the AliPay app:

    • Verify your mobile phone;
    • When asked, set up the PIN. Warning it is very important not to forget any of the codes, as you'll irreversibly lose access to your account;
  3. Verify your identity:

    1. Select "Account" tab;
    2. Tap on the profile avatar;
    3. Select "My Namecard";
    4. Press "Verify identity";
    5. Choose "Complete verification".

    After that, you'll be presented with a couple of possible age verification methods.
    Depending on your country one of them may work for you.

    ![Age verification method selection] ![Scanning a biometric pasport]

    Thanks to @ihrapsa for providing images and directions for this step
  4. On the main page, tap on a search bar, search for "NFC". An icon with "NFC" should appear, tap on it;

    ![Searching for NFC in AliPay] ![Searching for NFC in AliPay] ![NFC search results in AliPay]

  5. Follow the onboarding screens. In case you're unsure about the UI elements, make a screenshot and feed it into a translator app;

    ![Onboarding screen]

  6. When reaching the screen with card selection, choose any. Beware that some have different minimum topup amounts.

    ![Selecting a card]

  7. After selection, choose topup amount, pay for a card. Go to the next screen;

    ![Selecting a card]

  8. Apple Wallet UI should appear, inviting you to provision the new card. Follow the steps as usual.

    ![Provisioning T-Union card into wallet]

Having done all these steps, you should have a magic card in your Wallet. Use as you see fit. Good luck!

Notes

  • If you find any mistakes/typos or have extra information to add, feel free to raise an issue or create a pull request.

References

About

Using your Apple device as an access card in unsupported systems

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published