/*************************************************************************** * Copyright (C) 2005-2007 by Tarek Saidi * * tarek.saidi@arcor.de * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; version 2 of the License. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ #ifndef _STD_DATABASE_H_ #define _STD_DATABASE_H_ #include #define DB_HEADER_SIZE 124 #define PWM_DBSIG_1 0x9AA2D903 #define PWM_DBSIG_2 0xB54BFB65 #define PWM_DBVER_DW 0x00030002 #define PWM_FLAG_SHA2 1 #define PWM_FLAG_RIJNDAEL 2 #define PWM_FLAG_ARCFOUR 4 #define PWM_FLAG_TWOFISH 8 #define PWM_STD_KEYENCROUNDS 6000 void memcpyFromLEnd32(quint32* dst,const char* src); void memcpyFromLEnd16(quint16* dst,const char* src); void memcpyToLEnd32(char* src,const quint32* dst); void memcpyToLEnd16(char* src,const quint16* dst); //! Implementation of the standard KeePassX database. class Kdb3Database:public ICustomIcons,public IDatabase, public IKdbSettings{ Q_OBJECT public: class StdGroup; class StdEntry; class EntryHandle:public IEntryHandle{ friend class Kdb3Database; public: EntryHandle(Kdb3Database* db); virtual void setImage(const quint32& ImageID); virtual void setTitle(const QString& Title); virtual void setUrl(const QString& URL); virtual void setUsername(const QString& Username); virtual void setPassword(const SecString& Password); virtual void setComment(const QString& Comment); virtual void setBinaryDesc(const QString& BinaryDesc); virtual void setCreation(const KpxDateTime& Creation); virtual void setLastMod(const KpxDateTime& LastMod); virtual void setLastAccess(const KpxDateTime& LastAccess); virtual void setExpire(const KpxDateTime& Expire); virtual void setBinary(const QByteArray& BinaryData); virtual KpxUuid uuid(); virtual IGroupHandle* group(); virtual quint32 image(); virtual int visualIndex() const; virtual void setVisualIndex(int i); virtual void setVisualIndexDirectly(int i); virtual QString title(); virtual QString url(); virtual QString username(); virtual SecString password(); virtual QString comment(); virtual QString binaryDesc(); virtual KpxDateTime creation(); virtual KpxDateTime lastMod(); virtual KpxDateTime lastAccess(); virtual KpxDateTime expire(); virtual QByteArray binary(); virtual quint32 binarySize(); virtual QString friendlySize(); virtual bool isValid() const; private: void invalidate(){valid=false;} bool valid; //KpxUuid Uuid; ??? Kdb3Database* pDB; StdEntry* Entry; }; class GroupHandle:public IGroupHandle{ friend class Kdb3Database; GroupHandle(Kdb3Database* db); public: virtual void setTitle(const QString& Title); virtual void setImage(const quint32& ImageId); virtual QString title(); virtual quint32 image(); virtual bool isValid(); virtual IGroupHandle* parent(); virtual QList childs(); virtual int index(); virtual void setIndex(int index); virtual int level(); virtual bool expanded(); virtual void setExpanded(bool IsExpanded); private: void invalidate(){valid=false;} bool valid; StdGroup* Group; Kdb3Database* pDB; }; friend class EntryHandle; friend class GroupHandle; class StdEntry:public CEntry{ public: quint16 Index; EntryHandle* Handle; StdGroup* Group; }; class StdGroup:public CGroup{ public: StdGroup():CGroup(){}; StdGroup(const CGroup&); quint16 Index; StdGroup* Parent; GroupHandle* Handle; QList Childs; QList Entries; }; class TrashEntry: public StdEntry{ public: QStringList GroupPath; }; virtual ~Kdb3Database(){}; virtual bool load(QString identifier); virtual bool save(); virtual bool close(); virtual void create(); virtual int numEntries(); virtual int numGroups(); virtual QString getError(); virtual bool isKeyError(); virtual void cleanUpHandles(); virtual QPixmap& icon(int index); virtual int numIcons(); virtual void addIcon(const QPixmap& icon); virtual void removeIcon(int index); virtual void replaceIcon(int index,const QPixmap& icon); virtual int builtinIcons(){return BUILTIN_ICONS;}; virtual QList search(IGroupHandle* Group,const QString& SearchString, bool CaseSensitve, bool RegExp,bool Recursive,bool* Fields); virtual QFile* file(){return File;} virtual bool changeFile(const QString& filename); virtual void setCryptAlgorithm(CryptAlgorithm algo){Algorithm=algo;} virtual CryptAlgorithm cryptAlgorithm(){return Algorithm;} virtual unsigned int keyTransfRounds(){return KeyTransfRounds;} virtual void setKeyTransfRounds(unsigned int rounds){KeyTransfRounds=rounds;} virtual bool setKey(const QString& password, const QString& keyfile); virtual bool setPasswordKey(const QString& password); virtual bool setFileKey(const QString& filename); virtual bool setCompositeKey(const QString& password,const QString& filename); virtual QList entries(); virtual QList entries(IGroupHandle* Group); virtual QList expiredEntries(); virtual IEntryHandle* cloneEntry(const IEntryHandle* entry); virtual void deleteEntry(IEntryHandle* entry); virtual void deleteEntries(QList entries); virtual IEntryHandle* newEntry(IGroupHandle* group); virtual IEntryHandle* addEntry(const CEntry* NewEntry, IGroupHandle* group); virtual void moveEntry(IEntryHandle* entry, IGroupHandle* group); virtual void deleteLastEntry(); virtual void moveToTrash(IEntryHandle* entry); virtual QList trashEntries(); virtual void emptyTrash(); virtual QList groups(); virtual QList sortedGroups(); virtual void deleteGroup(IGroupHandle* group); virtual void moveGroup(IGroupHandle* Group,IGroupHandle* NewParent,int Position); virtual IGroupHandle* addGroup(const CGroup* Group,IGroupHandle* Parent); virtual bool isParent(IGroupHandle* parent, IGroupHandle* child); private: QDateTime dateFromPackedStruct5(const unsigned char* pBytes); void dateToPackedStruct5(const QDateTime& datetime, unsigned char* dst); bool isMetaStream(StdEntry& Entry); bool parseMetaStream(const StdEntry& Entry); void parseCustomIconsMetaStream(const QByteArray& data); void parseCustomIconsMetaStreamV3(const QByteArray& data); void parseGroupTreeStateMetaStream(const QByteArray& data); void createCustomIconsMetaStream(StdEntry* e); void createGroupTreeStateMetaStream(StdEntry* e); bool readEntryField(StdEntry* entry, quint16 FieldType, quint32 FieldSize, quint8 *pData); bool readGroupField(StdGroup* group,QList& Levels,quint16 FieldType, quint32 FieldSize, quint8 *pData); bool createGroupTree(QList& Levels); void createHandles(); void invalidateHandle(StdEntry* entry); bool convHexToBinaryKey(char* HexKey, char* dst); quint32 getNewGroupId(); void serializeEntries(QList& EntryList,char* buffer,unsigned int& pos); void serializeGroups(QList& GroupList,char* buffer,unsigned int& pos); void appendChildsToGroupList(QList& list,StdGroup& group); void appendChildsToGroupList(QList& list,StdGroup& group); bool searchStringContains(const QString& search, const QString& string,bool Cs, bool RegExp); void getEntriesRecursive(IGroupHandle* Group, QList& EntryList); void rebuildIndices(QList& list); void restoreGroupTreeState(); StdEntry* getEntry(const KpxUuid& uuid); StdEntry* getEntry(EntryHandle* handle); int getEntryListIndex(EntryHandle* handle); EntryHandle* getHandle(StdEntry* entry); StdGroup* getGroup(quint32 Id); void deleteGroup(StdGroup* group); QList EntryHandles; QList GroupHandles; QList TrashHandles; QList Entries; QList Groups; QList TrashEntries; StdGroup RootGroup; QListCustomIcons; QFile* File; QString error; bool KeyError; bool PotentialEncodingIssue; QList UnknownMetaStreams; QMap TreeStateMetaStream; unsigned int KeyTransfRounds; CryptAlgorithm Algorithm; quint8 RawMasterKey[32]; quint8 RawMasterKey_Latin1[32]; quint8 MasterKey[32]; bool hasV4IconMetaStream; }; class KeyTransform : public QThread{ Q_OBJECT public: static void transform(quint8* src, quint8* dst, quint8* KeySeed, int rounds); private: KeyTransform(quint8* pSrc, quint8* pDst, quint8* pKeySeed, int pRounds); quint8* src; quint8* dst; quint8* KeySeed; int rounds; protected: void run(); }; class KeyTransformBenchmark : public QThread{ Q_OBJECT public: static int benchmark(int pMSecs); private: KeyTransformBenchmark(int pMSecs); int msecs; int rounds; protected: void run(); }; #endif