This is a continuation of my own old post that became inactive to regain traction. I am trying to resolve issues that arise when distributing a macOS app with a SysExt Network Extension (Packet Tunnel) outside the App Store using a Developer ID Certificate. To directly distribute the app, I start with exporting the .app via Archive in Xcode. After that, I create a new Developer ID provisioning profile for both the app and sysext and replace the embedded ones in the .app package. After I have replaced the provisioning profiles and the have the entitlements files ready, I start signing the frameworks, sysext and parent app. codesign --force --options runtime --timestamp --sign Developer ID Application: .app/Contents/Library/SystemExtensions/.systemextension/Contents/Frameworks/.framework/Versions/A/ codesign --force --options runtime --timestamp --sign Developer ID Application:  .app/Contents/Frameworks/.framework/ codesign --force --options runtime --entitlements dist-vpn.entitlement
                    
                  
                
              
              
                
                Topic:
                  
	
		Code Signing
  	
                
                
                SubTopic:
                  
                    
	
		Entitlements
		
  	
                  
                
              
              
                Tags:
              
              
  
  
    
      
      
      
        
          
            Network Extension
          
        
        
      
      
    
      
      
      
        
          
            Gatekeeper
          
        
        
      
      
    
      
      
      
        
          
            Code Signing
          
        
        
      
      
    
      
      
      
        
          
            Developer ID