Skip to main content

ArborXR Field Provisioning Tools

Project description

ArborXR Field Provisioning Tools

This project is a collection of tools to help provision and recover Android devices on ArborXR's XRDM. The provisioning tools can be used interactively on a computer, or deployed onto the ArborXR Field Provisioning Device (FPD). The tools are intended to be used without the need for network connectivity to the ArborXR XRDM backend.

Features

  • Provision new Android devices (XR, Phone, Tablet) with an XRDM configuration package.
  • Re-provision existing devices with a configuration package.
  • Replace an XRDM client with an older or newer version.

Table of Contents

Field Provisioning Device (FPD)

The ArborXR Field Provisioning Device is a headless computer which can deploy XRDM1 Configuration Packages without the need for internet access.

Hardware Information

Currently supported hardware is currently a Raspberry Pi Zero 2 W running RBPI OS 64-bit. There are custom modifications made to the base image to support the dual mode USB (host/gadget). The image customizations are currenly not well documented, and in the future should be captured in code to be able to apply to a fresh RBPI OS image.

device_start.sh - This is a specific script which is launched by systemd to automatically start the provisioning tool on the FPD. There is a check to see if a certain GPIO is set to check for "Setup" or "Provision" mode is set.

Setup Mode

When the FPD selector switch is in "Setup" Mode, the device can be connected to any computer and will show up as a "Mass Storage Device". This is where the user can place XRDM Configuration Packages and/or an alternate client build.

You must follow a specific directory structure:

/configuration-packages

Place XRDM configuration packages here. Currently undetermined behavior if you place multiple configuration packages which apply to the same device. We don't have logic which can select the "best" package. Make sure you only place one per device type

/client

(Optional) You can place an alternate client to use instead of what's included in the configuration package. This can be used when needing to downgrade the client version to recover a device.

field-provisioning-tools-update.zip

This is the update package. It will be read as soon as the device boots into "Provision" mode. It will automatically be deleted as soon as its applied.

Provision Mode

When the FPD selector switch is in "Provision" Mode, the device can be connected to any Android device which USB debugging is enabled, and it will automatically start provisioning the device with any available configuration package that matches the device model connected.

This all happens in a headless manner, but once the device is provisioned the FPD will stop, and wont start another provisioning run until a new device is detected.

Currently XR devices require USB power injection due to the FPD HW not being able to supply enough current. Please use the included wall outlet and connector.

Development Environment Setup

Python 3.x is required.

  1. Clone the repository:

  2. Create and activate a virtual environment:

    python3 -m venv venv
    source venv/bin/activate  # On Windows use `venv\Scripts\activate`
    
  3. Install the dependencies:

    pip install -r requirements.txt
    

Running the Provisioning Tool

To run the provisioning tool, use the following command to install it into the path:

install.sh

Then it can be run using

abxr-provision

On non-Linux systems (MacOS/Windows) will start the provisioner in "single shot mode". It loads with the default options:

  • Searches for configuration packages in $HOME/abxr/configuration-packages
  • Searches for any special client APK overrides in $HOME/abxr/client

You can override the base path by setting the ABXR_ARCHIVE_PATH environment variable before starting the provisioning tool.

You can also pass arguments to the application which allow to specify exact locations of the configuration packages, client, or specific device serial numbers to match. This is useful when using the application in a multi-device environment

abxr-provision --config-package <path-to-config-packages> --client <path-to-client-for-override> --device-serial <specific-device-to-target> --force-upgrade

All of the command line switches are optional, and can be used interchangably. The force upgrade option will always reinstall the client even if the versions match.

Building a update package for the provisioning hardware

build_update_package.sh

This will package the project into a zip archive called field-provisioning-tools-update.zip that can be placed in the root directory of the HW provisioning device when mounted in "Setup Mode". When the device is booted back in provisioning mode, the update will automatically be applied.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

abxrfpt-0.5.0.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

abxrfpt-0.5.0-py3-none-any.whl (16.7 kB view details)

Uploaded Python 3

File details

Details for the file abxrfpt-0.5.0.tar.gz.

File metadata

  • Download URL: abxrfpt-0.5.0.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for abxrfpt-0.5.0.tar.gz
Algorithm Hash digest
SHA256 ff57d53af69e20873e794da7a44aa27534655d9fd51af0549c1a9f026d9b05ef
MD5 f6f7b075ac6c20c481d79679afe0e0b1
BLAKE2b-256 43176c58d41fa250050d54138582ca3a033a597f4d9938ca69c83048be44ce7a

See more details on using hashes here.

File details

Details for the file abxrfpt-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: abxrfpt-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 16.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for abxrfpt-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 38695642887113713bbb9baaac115f0c38c1ed7fea4f2129f03d847494a6bf2a
MD5 eb935b8154f63f0f2d7255631e1b6c34
BLAKE2b-256 f07cf3c38cabb0ca4297cadd27ea36c6330b9fce903dad2f7a64894a7a1e2352

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page