Skip to content

IntuneBrew is a PowerShell-based tool that simplifies the process of uploading and managing macOS applications in Microsoft Intune. It automates the entire workflow from downloading apps to uploading them to Intune, complete with proper metadata and logos.

License

Notifications You must be signed in to change notification settings

ugurkocde/IntuneBrew

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

IntuneBrew_Header

🍺 IntuneBrew

IntuneBrew is a PowerShell-based tool that simplifies the process of uploading and managing macOS applications in Microsoft Intune. It automates the entire workflow from downloading apps to uploading them to Intune, complete with proper metadata and logos.

πŸ“š Table of Contents

🚨 Public Preview Notice

Important

🚧 Public Preview Notice

IntuneBrew is currently in Public Preview. While it's fully functional, you might encounter some rough edges. Your feedback and contributions are crucial in making this tool better!

Thank you for being an early adopter! πŸ™

πŸ”„ Latest Updates

Last checked: 2025-01-18 00:14 UTC

Application Previous Version New Version
Microsoft Teams 24335.204.3298.2649 24335.207.3345.5574
Adobe Acrobat Reader 24.004.20272 24.005.20320
Bitwarden 2025.1.0 2025.1.1

✨ Features

  • πŸš€ Automated app uploads to Microsoft Intune
  • πŸ“¦ Supports both .dmg and .pkg files
  • πŸ”„ Automatic version checking and updates
  • πŸ–ΌοΈ Automatic app icon integration
  • πŸ“Š Progress tracking for large file uploads
  • πŸ” Secure authentication with Microsoft Graph API
  • 🎯 Smart duplicate detection
  • πŸ’« Bulk upload support
  • πŸ” Automatic retry mechanism for failed uploads
  • πŸ”’ Secure file encryption for uploads
  • πŸ“ˆ Real-time progress monitoring

🎬 Demo

IntuneBrew Demo

πŸš€ Getting Started

Prerequisites

  • PowerShell 7.0 or higher
  • Microsoft Graph PowerShell SDK
  • Azure App Registration with appropriate permissions OR Manual Connection via Interactive Sign-In
  • Windows or macOS operating system
  • Stable internet connection for large file uploads
  • Sufficient disk space for temporary file processing

Installation

  1. Clone the repository:
  2. Install required PowerShell modules:
Install-Module Microsoft.Graph.Authentication -Scope CurrentUser
  1. Configure your environment variables or update the config file with your Azure AD details.

πŸ“ Usage

Basic Usage

.\IntuneBrew.ps1

Follow the interactive prompts to:

  1. Select which apps to upload
  2. Authenticate with Microsoft Graph
  3. Monitor the upload progress
  4. View the results in Intune

πŸ“± Supported Applications

Application Latest Version
Adobe Acrobat Pro DC 24.005.20320
Adobe Acrobat Reader 24.005.20320
Adobe Creative Cloud 6.4.0.361
Android Studio 2024.2.2.13
AnyDesk 8.1.4
Asana 1.0
BetterDisplay 3.3.0
Bitwarden 2025.1.1
Blender 4.3.2
Brave 1.74.48.0
Canva 1.101.0
Company Portal 5.2412.0
DeepL 1.0
Docker Desktop 4.37.2,179585
Dropbox 215.4.7202
Evernote 10.105.4,20240910164757,a2e60a8d876a07eded5d212fa56ba45214114ad0
Google Chrome 132.0.6834.84
Grammarly Desktop 1.102.0.0
KeePassXC 2.7.9
Krisp 2.51.3
Microsoft Teams 24335.207.3345.5574
Miro 0.10.80
MongoDB Compass 1.45.1
Mozilla Firefox 134.0.1
Notion 4.3.0
Obsidian 1.7.7
Parallels Desktop 20.2.0-55872
PowerShell 7.4.6
Raycast 1.89.0
Real VNC Viewer 7.13.1
Remote Help 1.0.2404171
RStudio 2024.12.0,467
Signal 7.38.0
Slack 4.41.105
Snagit 2024.4.0
Spotify 1.2.53.440
Suspicious Package 4.5,1213
Synology Drive 3.5.1,16102
Tableau Desktop 2024.3.2
TeamViewer QuickSupport 15
Todoist 9.9.7
UTM 4.6.4
VLC media player 3.0.21
Webex Teams 45.1.0.31549
Windows App 11.0.9
XMind 25.01.01061-202501070704
Zoom 6.3.6.47101

Note

Missing an app? Feel free to request additional app support by creating an issue!

πŸ”§ Configuration

Azure App Registration

  1. Create a new App Registration in Azure
  2. Add the following API permissions:
    • DeviceManagementApps.ReadWrite.All
  3. Update the parameters in the script with your Azure details.
    • $appid = '' # App ID of the App Registration
    • $tenantid = '' # Tenant ID of your EntraID
    • $certThumbprint = '' # Thumbprint of the certificate associated with the App Registration

Certificate-Based Authentication

  1. Generate a self-signed certificate:
$cert = New-SelfSignedCertificate -Subject "CN=IntuneBrew" -CertStoreLocation "Cert:\CurrentUser\My" -KeyExportPolicy Exportable -KeySpec Signature -KeyLength 2048 -KeyAlgorithm RSA -HashAlgorithm SHA256 -NotAfter (Get-Date).AddYears(2)
  1. Export the certificate:
$pwd = ConvertTo-SecureString -String "YourPassword" -Force -AsPlainText
Export-PfxCertificate -Cert $cert -FilePath "IntuneBrew.pfx" -Password $pwd
  1. Upload to Azure App Registration:
    • Go to your App Registration in Azure Portal
    • Navigate to "Certificates & secrets"
    • Upload the public key portion of your certificate

App JSON Structure

Apps are defined in JSON files with the following structure:

{
    "name": "Application Name",
    "description": "Application Description",
    "version": "1.0.0",
    "url": "https://download.url/app.dmg",
    "bundleId": "com.example.app",
    "homepage": "https://app.homepage.com",
    "fileName": "app.dmg"
}

πŸ”„ Version Management

IntuneBrew implements sophisticated version comparison logic:

  • Handles various version formats (semantic versioning, build numbers)
  • Supports complex version strings (e.g., "1.2.3,45678")
  • Manages version-specific updates and rollbacks
  • Provides clear version difference visualization

Version comparison rules:

  1. Main version numbers are compared first (1.2.3 vs 1.2.4)
  2. Build numbers are compared if main versions match
  3. Special handling for complex version strings with build identifiers

πŸ› οΈ Error Handling

IntuneBrew includes robust error handling mechanisms:

  1. Upload Retry Logic

    • Automatic retry for failed uploads (up to 3 attempts)
    • Exponential backoff between retries
    • New SAS token generation for expired URLs
  2. File Processing

    • Temporary file cleanup
    • Handle locked files
    • Memory management for large files
  3. Network Issues

    • Connection timeout handling
    • Bandwidth throttling
    • Resume interrupted uploads
  4. Authentication

    • Token refresh handling
    • Certificate expiration checks
    • Fallback to interactive login

πŸ€” Troubleshooting

Common Issues

  1. File Access Errors

    • Ensure no other process is using the file
    • Try deleting temporary files manually
    • Restart the script
  2. Upload Failures

    • Check your internet connection
    • Verify Azure AD permissions
    • Ensure file sizes don't exceed Intune limits
  3. Authentication Issues

    • Verify your Azure AD credentials
    • Check tenant ID configuration
    • Ensure required permissions are granted

🀝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

πŸ“œ License

This project is licensed under the MIT License - see the LICENSE file for details.

πŸ™ Acknowledgments

  • Thanks to all contributors who have helped shape IntuneBrew
  • Microsoft Graph API documentation and community
  • The PowerShell community for their invaluable resources

πŸ“ž Support

If you encounter any issues or have questions:

  1. Check the Issues page
  2. Review the troubleshooting guide
  3. Open a new issue if needed

Made with ❀️ by Ugur Koc

About

IntuneBrew is a PowerShell-based tool that simplifies the process of uploading and managing macOS applications in Microsoft Intune. It automates the entire workflow from downloading apps to uploading them to Intune, complete with proper metadata and logos.

Resources

License

Stars

Watchers

Forks

Sponsor this project

 

Contributors 3

  •  
  •  
  •