Courtesy: GitHub

Android NfcProvisioning Sample

This sample demonstrates how to use NFC to provision a new device with a device owner. Device owner is a specialized type of device administrator that can control device security and configuration. This sample itself is not a device owner, but it is a programming app that sends NFC message to an unprovisioned peer device and tells it to set up the specified device owner app.

Introduction

NFC Provisioning app is nothing but an ordinary Android Beam app that just sends out provisioning values to the peer device. This sample uses the values below.

  • EXTRA_PROVISIONING_DEVICE_ADMIN_PACKAGE_NAME - The package name of the mobile device management application that will be set as the profile owner or device owner.
  • EXTRA_PROVISIONING_LOCALE - The Locale that the device will be set to.
  • EXTRA_PROVISIONING_TIME_ZONE - The time zone AlarmManager that the device will be set to.
  • EXTRA_PROVISIONING_WIFI_SSID - The ssid of the wifi network that should be used during nfc device owner provisioning for downloading the mobile device management application.
  • EXTRA_PROVISIONING_WIFI_PASSWORD - The password of the wifi network in EXTRA_PROVISIONING_WIFI_SSID.

Store values in an instance of Properties. Get a byte array representation of the Properties using ByteArrayOutputStream. Create an NdefRecord with the MIME type of DevicePolicyManager.MIME_TYPE_PROVISIONING_NFC. Use NfcAdapter#setNdefPushMessage to set the NdefMessage as the message to be sent.

Pre-requisites

  • Android SDK 26
  • Android Build Tools v26.0.1
  • Android Support Repository

Screenshots

Screenshot

Getting Started

This sample uses the Gradle build system. To build this project, use the "gradlew build" command or use "Import Project" in Android Studio.

Support

If you've found an error in this sample, please file an issue: https://github.com/googlesamples/android-NfcProvisioning

Patches are encouraged, and may be submitted by forking this project and submitting a pull request through GitHub. Please see CONTRIBUTING.md for more details.

License

Copyright 2017 The Android Open Source Project, Inc.

Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

compile "com.android.support:support-v4:26.1.0"

compile "com.android.support:support-v13:26.1.0"

compile "com.android.support:cardview-v7:26.1.0"

compile "com.android.support:appcompat-v7:26.1.0"

compileSdkVersion 26

minSdkVersion 21

targetSdkVersion 26

package com.example.android.nfcprovisioning

versionCode 1

versionName 1.0

uses-permission

  • android.permission.NFC
  • android.permission.ACCESS_WIFI_STATE
  • android.permission.READ_EXTERNAL_STORAGE

MainActivity

A simple launcher activity containing a summary sample description, sample log and a custom {@link android.support.v4.app.Fragment} which can display a view.

For devices with displays with a width of 720dp or greater, the sample log is always visible, on other devices it's visibility is controlled by an item on the Action Bar.

Create a chain of targets that will receive log data