I'm developing a shareware desktop application. I'm to the point where I need to implement the trial-use/activation code. How do you approach something like this? I have my own ideas, but I want to see what the stackoverflow community thinks.
I'm developing with C++/Qt. The intended platform is Windows/Mac/Linux.
Thanks for your advice!
What to protect against and what not to protect against:
Keep in mind that people will always find a way to get around your trial period. So you want to make it annoying for the person to have to get around your trial period, but it doesn't matter if it's impossible to get around you trial period.
Most people will think it's too much work to try and get around your trial period if there is even a simple mechanism. For example people can always use filemon/regmon to see which files and registry entries change upon installing your software.
That being said, a simple mechanism is best, because it wastes less of your time.
Here are some ideas:
Extending trials:
For us, when a customer requests a trial extension, we send them an automated email that contains a program "TrialExtend.exe" and a trial extend code. This program contacts our server with the trial extend code to validate it. If the code is validated, their trial period is reset.
Whatever you do, keep a keen eye on the system date. The oldest trick in the book is to install an application at some point in the future and then return to the real date once the application stored the silly date on first run. Maybe synchronise the key with a online repository ?
Brian's answer's great, but I'd like to add something.
Linux users generally aren't used to paying for software, and they tend to be more tech-savvy and possibly even "religious" on open-source issues.
For that reason, I'd really recommend keeping it simple - it's really just a small barrier to make buying the software at least as easy as stealing it.
I'd suggest that it nags or disables certain features (eg saving) after the trial period rather than dying completely. Just an observation, but feature-based restrictions seem more common in the linux world.
As an aside, making the linux version a "first class" version - decent installer etc will help.
If you're relatively small, or your program's relatively niche, there's a pretty small chance anyone will bother to crack it - so just concentrate on making a good product with a straight forward niggle once the time's up.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With