Skip to content
This repository has been archived by the owner on Dec 9, 2024. It is now read-only.

Workspace ONE Commands is an open source iOS swift project that provides enterprise IT admins to easily customize, build and deploy an IT focussed iOS application purpose built to perform on-demand MDM actions

License

Notifications You must be signed in to change notification settings

omnissa-archive/workspaceone-commands-for-ios

Repository files navigation

WS1_Actions.png?raw=true

Workspace ONE Commands for iOS

What is it?

Workspace ONE Commands is an open source iOS swift project that provides enterprise IT admins to easily customize, build and deploy an IT focussed iOS application purpose built to perform on-demand MDM actions such as Device Wipe, Enterprise Wipe, and Clear Passcode on their own device. The application can be entirely customized using Application Configuration to choose which actions to show in the app.

Each of the commands available in the App are APIs as part of the Workspace ONE UEM solution. App config values configure the corresponding command to be made visible in the App UI

The simple user interface with a grid of actions keeps it extremely simple for users to launch the app and tap the button.

Why is it available as Open-Source?

We believe this iOS project can truly harness the power of Workspace ONE UEM APIs and open doors for innovate line of business workflows. And ofcourse, it was a pretty simple app.

  • Branding : One of the advantages of providing the source code for the project is that it allows any organization to rename, brand and customize the application icon with their logo for easy discovery and familiarity

  • Extensibility and community: The open source project gives the opportunity for any organization to fork, and add any more features to the app as necessary. It preferred we encourage raising a Pull Request to add any new features that others may also benefit from.


How to deploy the app?

The source code can be signed and compiled with an Apple Enterprise Developer Account, that allows for distribution through couple different methods :

Enterprise App Distribution

The archive (.ipa) built with Enterprise Developer account along with a provisioning profile can be uploaded to Workspace ONE UEM console and assigned to devices using smart groups. For more information on deploying enterprise apps with Workspace ONE UEM refer this document.

Custom App

AppStore Connect Settings to release as a Custom App

To successfully go through AppStore Review, Apple should be able to test the app functionality. For this purpose, there is a demo mode added to the application that pops up a screen with manual input of information that will in practice be deployed through AppConfig. One of the easiest ways to help Apple test the demo mode is to create a test Organization group in a UAT environment, with REST API enabled, test admin account with API permissions and a test iOS device enrolled. Share the environment hostname (for eg: https://cn135.awmdm.com), API Token, Username and Password of the test admin account and the device identifier of the enrolled test device (This ID can be found in the URL when hovering over the device record in the admin console)

To make it easier for submission, here's a quick write up that can be used for submission:

This is an IT focussed application that works in conjunction with Mobile Device Management (MDM), where the functionality for the application is unlocked using MDM defined Application Configuration. The usage of this app is strictly in IT workflows for iPads / iPhones that are shared in a line of business workflow where the App includes quick actions that the user can take to do things like "Factory Wipe", "Device Sync". There is no sign in information required for the application as it is entirely configured using Managed App Config.

For more information on App Config, please refer :
https://developer.apple.com/documentation/devicemanagement/installapplicationcommand/command
https://www.apple.com/business/docs/resources/Managing_Devices_and_Corporate_Data_on_iOS.pdf

NOTE : This application does NOT trigger MDM enrollment, but is instead deployed as a Managed Application after an MDM enrollment.

Source Code for the application is available here: https://github.com/omnissa-archive/workspaceone-commands-for-ios

You can use any MDM solution to test the app with the App Config information provided in the Github repo above.

For the purposes of App Review, we've created a manual input screen to input information that would typically be deployed over the-air using Mobile Device Management.

Instructions to test:

Hostname : {INSERT HOSTNAME}
API Key : {INSERT API TOKEN}
Username : {INSERT ADMIN USERNAME}
Password : {INSERT ADMIN PASSWORD}
Device Identifier : {INSERT TEST DEVICE ID}

The default action for demo mode is "Sync Device", which syncs the device with the device management server to get necessary applications and policies over the air. A demo device has been staged to test the sync.

Select the private distribution option with the Organization ID for the Apple Business Manager account

Example : Distribution.png?raw=true

Deployment

Deploying as a Custom App with the help of Apple Business Manager will be the most preferred method going forward. For more information on Custom Apps check this Techzone tutorial. The Application Configuration keys described above can be added to the app deployment during the assignment phase, as outlined in Step 8 of the Assigning Custom Apps to Devices section.

How to configure the app?

Pre-requisites

  • Access to Workspace ONE UEM console
  • API service account (needed as input in Appconfig below)
  • API token (needed as input in AppConfig below)

When deploying the app to devices, use the following values in the Application Configuration section to configure the app appropriately:

Key Type Requirement Function
DEVICE_UID string Required Set to {DeviceUid}
API_HOSTNAME string Required The API URL for the WS1 UEM environment. Use the form https://apiurl.com/api
API_KEY string Required The REST API key configured in your WS1 UEM Organization Group
API_USERNAME string Required The username of a WS1 UEM administrator account that has the appropriate permissions to perform the specified actions. By default you can use an administrator account with the "Console Administrator" role.
API_PASSWORD string Required The password to the WS1 UEM administrator account specified above
ENABLE_TROUBLESHOOTING bool Optional If set to true, will enable a Troubleshooting menu within WS1 Actions where the user can see all applied configurations and API information. Set to false by default.
ACTION_WIPE bool Optional If set to true, enables the "Device Wipe" action. Set to false by default.
ACTION_ENTERPRISEWIPE bool Optional If set to true, enables the "Enterprise Wipe" action. Set to false by default.
ACTION_CLEARPASSCODE bool Optional If set to true, enables the "Clear Passcode" action. Set to false by default.
ACTION_SYNC bool Optional If set to true, enables the "Device Sync" action. Set to false by default.

Rather than creating each of these keys manually, you can use the Upload XML button when configuring the Application Configuration in the Workspace ONE UEM Console. Use the sample XML file located in the bin folder as a starting point, and then modify the key values as needed in the Workspace ONE UEM Console.

Support

Workspace ONE Commands for iOS project is released as open source software and, presently, provides community support through our GitHub project page and comes with no commercial support. If you encounter an issue or have a question, feel free to reach out via GitHub issues

Contributing

The Workspace ONE Commands for iOS project team welcomes contributions from the community.

About

Workspace ONE Commands is an open source iOS swift project that provides enterprise IT admins to easily customize, build and deploy an IT focussed iOS application purpose built to perform on-demand MDM actions

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages