Skip to content
This repository has been archived by the owner on Jul 23, 2024. It is now read-only.
/ InQRy Public archive

A robust, cross-platform inventory utility that generates a QR code containing system hardware specs.

License

Notifications You must be signed in to change notification settings

microsoft/InQRy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

InQRy

A robust, cross-platform utility that generates a QR code containing hardware specs of the target machine or device.

⚠️ InQRy is not actively maintained. However, pull requests will not be ignored.

Requirements

  • Python 3.4 and later

Supported platforms

  • OS X 10.10 and later
  • Windows 10
  • Windows Server 2012 R2 and later

About

Written in pure Python, InQRy is designed to obtain asset information both quickly and accurately, without having to rely on data imports or asset-owner participation during physical inventory. The QR code contains detailed information about the client machine or device, which can then be scanned to quickly add the asset into a web-based inventory system, such as Snipe-IT.

Though originally designed to work on only laptop and desktop computers, it is now capable of obtaining the hardware specs of any number of attached iOS devices, pending that Apple's command-line utility cfgutil is installed via Apple Configurator 2.

Install and run

pip3 install inqry
python3 -m inqry

Build on macOS

Requirements

Instructions

Run the following command to build the InQRy app. The output will be under dist/

python3 setup.py py2app --iconfile icon/Icon.icns

Build on Windows

Requirements

Instructions

Run the following command to build the InQRy app. The output will be under dist/

pyinstaller --onefile --icon icon/Icon.ico inqry/__main__.py

How it works

InQRy obtains hardware specs using platform-specific shell commands and Python modules. Data is parsed and given to SystemSpecs object, where it is homogenized and passed to the FormInstructions class, where even more data is added and manipulated to work with the Snipe-IT inventory system. Instructions containing that data are used to create a python-qrcode-generated code, which is displayed on the screen for scanning.

InQRy determines which instructions to follow based on a combination of user input and the machine itself. Those instructions contain other important information that allow it to move fluidly through different types of fields in the Snipe-IT asset entry form.

Usage

Example usage of an InQRy SystemSpecs object:

>>> from inqry.system_specs import systemspecs
>>> ss = systemspecs.SystemSpecs()
>>> ss.os_type
'Darwin'
>>> ss.memory
'8 GB'
>>> ss.storage
{'Drive 1': '251.0 GB SSD (APPLE SSD AP0256J)'}

Screenshot

InQRy GUI

Limitations

  • The CR1400 series QR code reader is required to use the QR code with an entry form. See the barcode scanner README for more information.

  • The FormInstructions class is written to support our own custom fields and fieldsets for Snipe-IT. You may need to modify the FormInstructions class in order to use this in your environment. However, most of its attributes should be compatible with similar asset-entry forms.

  • Obtaining mobile device hardware specs is limited to iOS devices, and contingent upon having installed cfgutil via Apple Configurator 2.

Issues

Microsoft Internal Only