Skip to content

Latest commit

 

History

History
167 lines (127 loc) · 8.36 KB

README.md

File metadata and controls

167 lines (127 loc) · 8.36 KB

Overviewanalytics

Instructions and code for setting up a simple iOS Mobile Device Management (MDM) server. MDM allows for OS level control of multiple devices from a centralized location. A remote administrator can install/remove apps, install/revoke certificates, lock the device, change password requirements, etc.

Prerequisites

  • Publicly accessible Linux/Unix server
  • Apple Enterprise Account
  • Apple Developer Account
  • Python 2.7
  • openssl command-line
  • Java SDK (java/javac)
  • Apple's iPhone Configuration Utility

Certificate Setup

Instructions

  1. In the /scripts directory, open server.cnf. Replace all instances of <SERVER_IP> with your server's IP address.
  2. Run make_certs.sh, which can be found in the /scripts directory.
  • Carefully read the directions given for each step and follow the instructions
  • This should generate several certificates needed to move forward to the next step. See the Explanation section for more details.
  1. Go to Apple's [iOS Provisioning Portal](Apple Member Center). Upload customer.csr in the /scripts folder on the iOS Provisioning Portal.
  • You will be given the option to download a .cer file. Do so and name this file something along the lines of YOUR_MDM.cer.
  • Run the following openssl command in your terminal and then move the generated mdm.pem file to /vendor-signing/com/softhinker (it should replace an empty file of the same name). openssl x509 -inform der -in YOUR_MDM.cer -out mdm.pem
  1. Find Test.java in the /vendor-signing/com/softhinker folder. On line 95, replace the word test with the PEM password that you used when running make_certs.sh.
  • Replace only the word text so that your password is still in quotes.
  1. Run the vendor-signing.sh script found in the /scripts directory.
  • There now should be a file named plist_encoded located in /vendor-signing.
  1. Go to Apple's Push Certificates Portal and upload the plist_encoded file. Download the certificate as PushCert.pem and place it within the /server directory.
  • Notice the (i) icon beside the renew option. If you click it there will be a long string of text ending in UID=com.apple.mgmt..., make sure to copy that string starting at com since you will need it later.

Apple Portal

Explanation

Hopefully this works properly and generates 90% of what you need.

In the vendor-signing directory, under com/softhinker, you will notice several certificates are included:

  • customer.der
    • Must be replaced
    • Generated from make_certs.sh
    • Accept defaults for all other values (Including Challenge password)
  • intermediate.pem
    • Automatically replace by make_certs.sh
    • Apple's WWDR intermediate certificate
  • mdm.pem
    • Must be replaced
    • Obtain from [iOS Provisioning Portal](Apple Member Center)
    • Use customer.csr created by make_certs.sh
    • Download the file, should be in .cer format
    • Convert to pem: openssl x509 -inform der -in YOUR_MDM.cer -out mdm.pem
  • root.pem
    • Automatically replace by make_certs.sh
    • Apple's root certificate
  • vendor.p12
    • Must be replaced
    • Generated from make_certs.sh

After generating certificates and placing your PEM password in line 95 of Test.java, the vendor-signing.sh script will be run. This script takes several scripts we have already generated and creates a plist for use with apple's push certificates portal.

Enrollment profile

Open the iPhone Configuration Utilities program. Select Configuration Profiles click the New button, and fill out the sections as follows:

  • General
    • Name: A unique name for you to keep track of
    • Identifier: com.apple.mgmt... string you recorded during certificate generation
  • Certificates
    • Use vendor.p12 generated during certificate creation
    • Password: Enter the password you used during certificate creation
  • Mobile Device Management
    • Server URL: https://YOUR_HOSTNAME:8080/server
    • Check In URL: https://YOUR_HOSTNAME:8080/checkin
    • Topic: com.apple.mgmt... string
    • Identity: vendor.p12
    • Sign messages: Checked
    • Check out when removed: Unchecked
    • Query device for: Check all that you want
    • Add / Remove: Check all that you want
    • Security: Check all that you want
    • Use Development APNS server: Uncheck

Your screen should be similar to the following: Enrollment Configuration

After you are finished, highlight the entry in the table, and click Export. Choose None for security and then Export.... The export window should look like:
Enrollment Export

Save in the mdm-server/server/ directory as Enroll. You should now have an Enroll.mobileconfig file.

Server Setup

The server code based on and heavily takes from Intrepidus Group's blackhat presentation. Copy over the mdm-server/server directory you put the enrollment profile and certificates in to your server.

You must have the following installed on the server:

Network Settings

  • Outbound access to gateway.push.apple.com:2195
  • Inbound access to port 8080
  • iOS device must also have outbound access to gateway.push.apple.com:5223

If everything is setup appropriately, simply navigate to the /server directory and run python server.py.

On the device navigate to: https://YOUR_HOST:8080/ Once there you need to, in order:

  1. Tap here to install the CA Cert (for Server/Identity)
  2. Tap here to enroll in MDM (the device should appear after this step)
  3. Select Command (DeviceLock is a good one to test) and check your device. Click Submit to send the command.

Device Enrollment Steps

You can now run those commands from any web browser, a successfull command will often looks something like the following:


Command Success

Note: Image out of date. Working on a new image to replace it.

Client Reporting

The MDM server also has REST endpoints for reporting issues and geolocation data from the enrolled clients. The API can be imported into any project as follows:

  • Click on the top level Project item and add files ("option-command-a")
  • Navigate to client-reporting/
  • Highlight the client-reporting subdirectory
  • Click the Add button

The library provides the following functions:

+(void) setHostAddress: (NSString*) host; // Set where the MDM server lives
+(void) setPause : (BOOL) toggle; // Toggle whether to add a thread execution pause to allow requests to finish
+(void) reportJailbreak;  // Report that the device has been jailbroken
+(void) reportDebugger; // Report that the application has a debugger attached
+(void) reportLocation : (CLLocationCoordinate2D*) coords; // Report the lat/lon location of the device

"setHostAddress" and "setPause" are meant to be set once only, and effect all "report" calls. An example usage may look like:

// Code in application init
[client_reporting setHostAddress:@"192.168.0.0"];
[client_reporting setPause:YES];

// Later code during execution
[client_reporting reportDebugger]

This client API can be coupled with the iMAS security-check controls to provide accurate reporting of jailbreak and debugger detection.

Some sticking points that folks may run into:

  • Modify "scripts/server.cnf" to have your server's IP address in place of <SERVER_IP>.
  • Be careful to follow the prompts for each step of make_certs.sh, you do need to put things for common name when asked.