mhajas / Qt-SESAM

c't SESAM Password Manager (Qt version)

Home Page:http://ola-ct.github.io/Qt-SESAM

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

PV204 - PROJECT Qt-SESAM

Team members

  • Michal Hajas
  • Andrej Staruch
  • Andrea Turiaková

About

The goal of this project was to implement extension of Qt-SESAM application which allow user authenticate with security token - JavaCard. Card and application are communicating through secure channel to prevent multiple kind of attacks. Communication between them is secured by AES-128 with keys generated randomly for each session and using Diffie-Hellman for key exchange.

How to build

Extension of application is using functions defined in winscard.h header file for communication with card. In Linux winscard.h is provided by pcsc-lite package and in Windows by Winscard.lib included in Windows SDK.

Linux

Link to original guide: https://github.com/ola-ct/Qt-SESAM/wiki/Build-for-Linux Following this guide all should work properly, if not please check:

  • If you are building right project - Qt-SESAM not SESAM2Chrome or else
  • If you are not missing pcsc-lite package
  • Try uncheck shadow build in QT Creator

If problems persist do not hesitate to write to us.

Windows

With Qt Creator open the .pro file, press F5 to compile and run in debug mode. If you have problems with Winscard.lib try to copy this lib to project folder and add addres to this lib into .pro file.

For reviewers - Where to look for our changes

  • Qt-SESAM/java_card - extended application code
  • java_card_application - Javacard Applet
  • doc - presentation, project design
Below is the original description of Qt-SESAM application.

Qt-SESAM

SESAM — Super Easy & Secure Authentication Management

Qt-SESAM is a user-friendly application that enables you to generate strong passwords. You can use them for all the services you're using, e.g. websites, accounts, or apps.

The passwords are generated in realtime from service name, user name, a randomly shuffled salt and the master password. For services which don't allow passwords to be changed (e.g. credit cards) Qt-SESAM can also store fixed passwords.

Qt-SESAM has a unique feature which lets you choose the complexity (vertically) and length (horizontally) of the password in a colored widget:

EasySelectorWidget

You can share Qt-SESAM's settings across your computers via a dedicated synchronisation server and a file located on a cloud drive like OwnCloud, Google Drive, Microsoft OneDrive or Dropbox.

This is secure because all of your settings are AES-encrypted with a 256 bit long key and a 128 bit long IV derived from your master password with PBKDF2.

Qt-SESAM supports Windows, Linux and Mac OS X. An Android app compatible to Qt-SESAM is underway.

Download

Important infos

About

c't SESAM Password Manager (Qt version)

http://ola-ct.github.io/Qt-SESAM

License:GNU General Public License v3.0


Languages

Language:C++ 62.0%Language:C 28.7%Language:Java 4.9%Language:QMake 2.4%Language:JavaScript 1.7%Language:HTML 0.3%Language:CSS 0.1%Language:Batchfile 0.0%