-
Notifications
You must be signed in to change notification settings - Fork 0
System Profiling
Thanks to the work of Tom Harrington , Sparkle now supports optionally sending anonymous information about the user’s system with their update. Developers can use this information to better decide what platforms and hardware to support.
- Mac OS X version
- CPU type/subtype (see mach/machine.h for decoder information on this data)
- Mac model
- Number of CPUs (or CPU cores, in the case of something like a Core Duo)
- 32-bit vs. 64-bit
- CPU speed
- RAM size
- Application name (as indicated by CFBundleName)
- Application version (as indicated by CFBundleVersion)
- User’s preferred language
- Anything else you’d like to send along (via a delegate method; see Customizing Sparkle)
This information will be provided via GET, so if your feed URL is http://you.org/app.xml, the request will be made to http://you.org/app.xml?cpusubtype=4&ncpu=2&appName=App.app&cpuFreqMHz=1830[…].
Note: In order to standardize the statistics across a userbase with varying update check intervals, Sparkle submits profiling information only once per week.
First, you’ve got to tell Sparkle you want this data to be sent. You can do this by adding a SUEnableSystemProfiling
key to your app’s Info.plist and setting its value to YES.
Next, you’ve got to put something up server-side to collate and display the submitted information in a useful way. Tom Harrington has written a PHP-based backend; you can download it here. Backends based on other server-side languages would be very welcome, though!
Finally, set the SUFeedURL to your server-side script (eg. profileInfo.php) instead of the appcast. The script in turn should be set to link to the appcast.