Safe and SafeDesktop

(by Thomas King - king[at]t-king.de - http://www.t-king.de)



Please be aware that the successor of Safe and SafeDesktop is available at http://www.mobileknox.com.



What is Safe?

Nowadays, every person is forced to remember lots of sensitive data to interact with machines during daily life. For instance, automatic teller machines ask for numerical passwords and email accounts are protected by using loginnames and passwords. For many good reasons passwords should be difficult to guess and every password should be used for one account only. In reality, this makes it quite difficult for the average person to remember all the different passwords. Hence, people tend to choose easy to remember passwords and many persons re-use their passwords in such a way that the same password is used for many accounts. Even worse, it is quite common to write down a often-used password and stick the note containing the sensitive information to a screen frame. All these facilitations of remembrance lower the burden for hackers to get access to sensitive data and abuse computers.

The idea behind Safe is that a user must not remember all her loginnames and passwords. Instead, the user utilizes her cell phone to store sensitive data in an encrypted way. Only a so-called root password is required to be remembered to get access to the data.

This concept works pretty well, because nowadays, cell phones are ubiquitous. Usually, cell phone owners carry the phones in their pockets regardless where they are going. So, running Safe on a cell phone means that passwords have no longer be to remembered and can be chosen as difficult as it can be. The only requirement is that the cell phone in question supports J2ME applications and root password will never be forgotten.

What is SafeDesktop?

SafeDesktop provides the same features as Safe does but it runs on desktop machines. Java is also used for the implementation of SafeDesktop. This allows SafeDesktop to be executed on almost all modern desktop operating systems (e.g., Microsoft Windows, Linux).

A synchronization mechanism is part of SafeDesktop to keep the data synchronized between Safe and SafeDesktop.

How does it work?

A MD5 hash of the root password is stored on the mobile device and compared with the user's input that is requested at application's startup. If the hash of the user's input is equal with the stored hash, the IDEA cipher is used in CBC mode (of operation) to decrypt the data stored in an encrypted way. The password that the user entered at startup is used as key for the IDEA cipher.

Are screenshots available?

Safe:



SafeDesktop:



What do I need to run Safe?

A J2ME-enabled device that supports CLDC 1.0, MIDP 2.0, JSR75 (PDA Optional Package), and JSR172 (Web Service API (WSA)) is required to run Safe. Nowadays, any state-of-the-art cell phone should do the job.

For testing the J2ME wireless toolkit can be used.

What do I need to run SafeDesktop?

To run SafeDesktop you need the Java Runtime Environment 6. The Java Runtime Environment can be downloaded for free from Sun Inc. and it is available for all major desktop operating systems.

Download?

Safe (latest version is 2.4.1):

SafeDesktop (latest version is 0.9.8):

License?

Safe and SafeDesktop are distributed under the terms of the GPL.

How to setup Safe and SafeDesktop?

Do you need help to get synchronization between Safe and SafeDesktop to work? Please read the step-by-step instructions.

Forum?

A forum is available to facilitate discussion regarding Safe and SafeDesktop. Please feel free to post a message to the forum by sending an email to safe_and_safedesktop@googlegroups.com.

How can I contribute to the project?

There are many ways of contributing to the project:

Where do users come from?

You are a user of Safe or SafeDesktop? Please add yourself to the map to show others where you come from.

Who supports Safe and SafeDesktop?

Honor to whom honor is due. Special thanks for the following people who helped improving Safe and SafeDesktop:

ChangeLog?

Safe 2.4.1 (12/06/07):

Safe 2.4.0 (10/30/07):

Safe 2.3.2 (09/07/07):

Safe 2.2.6 (07/30/07):

Safe 2.1 (06/09/07):

Safe 2.0 (05/18/07):

Safe 1.2.0 (04/06/07):

Safe 1.1.0 (01/06/07):

Safe 1.0.4 (01/01/07):

Safe 1.0.3 (03/03/06):

Safe 1.0.2 (25/03/05):

Safe 1.0.2 (12/30/01):

Safe 1.0.1 (12/28/01):

Safe 1.0 (12/21/01):

Safe 1.0Beta2 (09/13/01):

Safe 1.0Beta1 (09/10/01):

SafeDesktop 0.9.8 (12/06/07):

SafeDesktop 0.9.7 (11/06/07):

SafeDesktop 0.9.6 (10/30/07):

SafeDesktop 0.9.5 (10/25/07):

SafeDesktop 0.9.4 (10/18/07):

SafeDesktop 0.9.3 (08/14/07):

SafeDesktop 0.9.2 (07/31/07):

SafeDesktop 0.9.1 (06/09/07):

SafeDesktop 0.9 (05/18/07):