showing 'group' column only when search results are shown,
added KWalletImport. git-svn-id: https://svn.code.sf.net/p/keepassx/code/trunk@128 b624d157-de02-0410-bad0-e51aec6abb33
This commit is contained in:
parent
6cae658d24
commit
2b54ded391
|
@ -21,59 +21,50 @@
|
||||||
#include "Import_KWalletXml.h"
|
#include "Import_KWalletXml.h"
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QtXml>
|
#include <QtXml>
|
||||||
|
#include <QMessageBox>
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
bool Import_KWalletXml::importFile(QString FileName,StandardDatabase* pwm,QString& err){
|
bool Import_KWalletXml::importDatabase(QWidget* GuiParent, IDatabase* db){
|
||||||
QFile file(FileName);
|
QFile* file=openFile(GuiParent,identifier(),QStringList()<<tr("XML Files (*.xml)")<<tr("All Files (*)"));
|
||||||
if(!file.exists()){
|
if(!file)return false;
|
||||||
err+=QObject::tr("File not found.");
|
int len=file->size();
|
||||||
return false;}
|
quint8* buffer=new quint8[len];
|
||||||
if(!file.open(QIODevice::ReadOnly)){
|
file->read((char*)buffer,len);
|
||||||
err+=QObject::tr("Could not open file.");
|
file->close();
|
||||||
return false;}
|
delete file;
|
||||||
int len=file.size();
|
QDomDocument doc;
|
||||||
if(len==0){
|
QString xmlerr;
|
||||||
err+=QObject::tr("File is empty.");
|
int col,line;
|
||||||
return false;}
|
if(!doc.setContent(QString::fromUtf8((char*)buffer,len),false,&xmlerr,&line,&col)){
|
||||||
quint8* buffer=new quint8[len];
|
qWarning("Import_PwManager::parseXmlContent():\n");
|
||||||
file.read((char*)buffer,len);
|
qWarning(((xmlerr+" (Line:%1 Column:%2)").arg(line).arg(col)+QString('\n')).toAscii());
|
||||||
file.close();
|
QMessageBox::critical(GuiParent,tr("Import Failed"),tr("Invalid XML data (see stdout for details)."));
|
||||||
QDomDocument doc;
|
delete [] buffer;
|
||||||
QString xmlerr;
|
return false;}
|
||||||
int col,line;
|
|
||||||
if(!doc.setContent(QString::fromUtf8((char*)buffer,len),false,&xmlerr,&line,&col)){
|
|
||||||
qWarning("Import_PwManager::parseXmlContent():\n");
|
|
||||||
qWarning(((xmlerr+" (Line:%1 Column:%2)").arg(line).arg(col)+QString('\n')).toAscii());
|
|
||||||
err+=QObject::tr("Invalid XML file (see stdout for details).");
|
|
||||||
delete [] buffer;
|
delete [] buffer;
|
||||||
return false;}
|
QDomElement root=doc.documentElement();
|
||||||
delete [] buffer;
|
if(root.tagName()!="wallet"){QMessageBox::critical(GuiParent,tr("Import Failed"),tr("Invalid XML file.")); return false;}
|
||||||
QDomElement root=doc.documentElement();
|
QDomNodeList groups=root.elementsByTagName("folder");
|
||||||
if(root.tagName()!="wallet"){err+=QObject::tr("Invalid XML file."); return false;}
|
if(!groups.length()){QMessageBox::critical(GuiParent,tr("Import Failed"),tr("Document does not contain data.")); return false;}
|
||||||
QDomNodeList groups=root.elementsByTagName("folder");
|
for(int i=0;i<groups.length();i++){
|
||||||
if(!groups.length()){err+=QObject::tr("Document does not contain data."); return false;}
|
if(!groups.item(i).isElement()){QMessageBox::critical(GuiParent,tr("Import Failed"),tr("Invalid XML file.")); return false;}
|
||||||
for(int i=0;i<groups.length();i++){
|
QDomElement CurrGroup=groups.item(i).toElement();
|
||||||
if(!groups.item(i).isElement()){err+=QObject::tr("Invalid XML file."); return false;}
|
if(!CurrGroup.hasAttribute("name")){QMessageBox::critical(GuiParent,tr("Import Failed"),tr("Invalid XML file.")); return false;}
|
||||||
QDomElement CurrGroup=groups.item(i).toElement();
|
CGroup NewGroup;
|
||||||
if(!CurrGroup.hasAttribute("name")){err+=QObject::tr("Invalid XML file."); return false;}
|
NewGroup.Title=CurrGroup.attribute("name");
|
||||||
IGroupHandle* NewGroup=pwm->addGroup(NULL);
|
IGroupHandle* NewGroupHandle=db->addGroup(&NewGroup,NULL);
|
||||||
NewGroup->Name=CurrGroup.attribute("name");
|
QDomNodeList entries=CurrGroup.elementsByTagName("password");
|
||||||
QDomNodeList entries=CurrGroup.elementsByTagName("password");
|
for(int j=0;j<entries.length();j++){
|
||||||
for(int j=0;j<entries.length();j++){
|
if(!entries.item(j).isElement()){QMessageBox::critical(GuiParent,tr("Import Failed"),tr("Invalid XML file.")); return false;}
|
||||||
if(!entries.item(j).isElement()){err+=QObject::tr("Invalid XML file."); return false;}
|
QDomElement CurrEntry=entries.item(j).toElement();
|
||||||
QDomElement CurrEntry=entries.item(j).toElement();
|
if(!CurrEntry.hasAttribute("name")){QMessageBox::critical(GuiParent,tr("Import Failed"),tr("Invalid XML file.")); return false;}
|
||||||
if(!CurrEntry.hasAttribute("name")){err+=QObject::tr("Invalid XML file."); return false;}
|
IEntryHandle* NewEntry=db->newEntry(NewGroupHandle);
|
||||||
IEntryHandle* NewEntry=pwm->addEntry();
|
NewEntry->setTitle(CurrEntry.attribute("name"));
|
||||||
NewEntry->Title=CurrEntry.attribute("name");
|
QString pw=CurrEntry.text();
|
||||||
NewEntry->GroupID=NewGroup->ID;
|
SecString pws;
|
||||||
QString pw=CurrEntry.text();
|
pws.setString(pw,true);
|
||||||
NewEntry->Password.setString(pw,true);
|
NewEntry->setPassword(pws);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
pwm->file=NULL;
|
return true;
|
||||||
pwm->SearchGroupID=-1;
|
}
|
||||||
pwm->CryptoAlgorithmus=ALGO_AES;
|
|
||||||
pwm->KeyEncRounds=6000;
|
|
||||||
return true;
|
|
||||||
}*/
|
|
|
@ -20,14 +20,14 @@
|
||||||
|
|
||||||
#ifndef _IMPORT_KWALLET_H_
|
#ifndef _IMPORT_KWALLET_H_
|
||||||
#define _IMPORT_KWALLET_H_
|
#define _IMPORT_KWALLET_H_
|
||||||
#include <qstring.h>
|
#include "Database.h"
|
||||||
#include "StandardDatabase.h"
|
#include "Import.h"
|
||||||
|
|
||||||
class Import_KWalletXml{
|
|
||||||
public:
|
|
||||||
bool importFile(QString FileName,StandardDatabase* db,QString& err);
|
|
||||||
private:
|
|
||||||
|
|
||||||
|
class Import_KWalletXml:public IImport, public ImporterBase{
|
||||||
|
public:
|
||||||
|
virtual bool importDatabase(QWidget* GuiParent, IDatabase* Database);
|
||||||
|
virtual QString identifier(){return "KWalletXml";}
|
||||||
|
virtual QString title(){return "KWallet XML File (*.xml)";}
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -224,7 +224,7 @@ void KeepassEntryView::updateEntry(EntryViewItem* item){
|
||||||
item->setText(j++,entry->lastAccess().dateToString(Qt::LocalDate));}
|
item->setText(j++,entry->lastAccess().dateToString(Qt::LocalDate));}
|
||||||
if(Columns[9]){
|
if(Columns[9]){
|
||||||
item->setText(j++,entry->binaryDesc());}
|
item->setText(j++,entry->binaryDesc());}
|
||||||
if(Columns[10]){
|
if(Columns[10] && ViewMode==ShowSearchResults){
|
||||||
item->setText(j,entry->group()->title());
|
item->setText(j,entry->group()->title());
|
||||||
item->setIcon(j++,db->icon(entry->group()->image()));}
|
item->setIcon(j++,db->icon(entry->group()->image()));}
|
||||||
}
|
}
|
||||||
|
@ -339,7 +339,11 @@ void KeepassEntryView::resizeEvent(QResizeEvent* e){
|
||||||
|
|
||||||
|
|
||||||
void KeepassEntryView::showSearchResults(){
|
void KeepassEntryView::showSearchResults(){
|
||||||
ViewMode=ShowSearchResults;
|
if(ViewMode==Normal){
|
||||||
|
ViewMode=ShowSearchResults;
|
||||||
|
if(Columns[10])ColumnOrder[10]--;
|
||||||
|
updateColumns();
|
||||||
|
}
|
||||||
clear();
|
clear();
|
||||||
Items.clear();
|
Items.clear();
|
||||||
createItems(SearchResults);
|
createItems(SearchResults);
|
||||||
|
@ -347,7 +351,10 @@ void KeepassEntryView::showSearchResults(){
|
||||||
|
|
||||||
|
|
||||||
void KeepassEntryView::showGroup(IGroupHandle* group){
|
void KeepassEntryView::showGroup(IGroupHandle* group){
|
||||||
ViewMode=Normal;
|
if(ViewMode==ShowSearchResults){
|
||||||
|
ViewMode=Normal;
|
||||||
|
updateColumns();
|
||||||
|
}
|
||||||
clear();
|
clear();
|
||||||
Items.clear();
|
Items.clear();
|
||||||
if(group==NULL)return;
|
if(group==NULL)return;
|
||||||
|
@ -393,7 +400,7 @@ void KeepassEntryView::createItems(QList<IEntryHandle*>& entries){
|
||||||
item->setText(j++,entries[i]->lastAccess().dateToString(Qt::LocalDate));}
|
item->setText(j++,entries[i]->lastAccess().dateToString(Qt::LocalDate));}
|
||||||
if(Columns[9]){
|
if(Columns[9]){
|
||||||
item->setText(j++,entries[i]->binaryDesc());}
|
item->setText(j++,entries[i]->binaryDesc());}
|
||||||
if(Columns[10]){
|
if(Columns[10] && ViewMode==ShowSearchResults){
|
||||||
item->setText(j,entries[i]->group()->title());
|
item->setText(j,entries[i]->group()->title());
|
||||||
item->setIcon(j++,db->icon(entries[i]->group()->image()));}
|
item->setIcon(j++,db->icon(entries[i]->group()->image()));}
|
||||||
}
|
}
|
||||||
|
@ -433,10 +440,14 @@ void KeepassEntryView::updateColumns(){
|
||||||
cols << tr("Last Access");}
|
cols << tr("Last Access");}
|
||||||
if(Columns[9]){
|
if(Columns[9]){
|
||||||
cols << tr("Attachment");}
|
cols << tr("Attachment");}
|
||||||
if(Columns[10]){
|
if(Columns[10] && ViewMode==ShowSearchResults){
|
||||||
cols << tr("Group");}
|
cols << tr("Group");}
|
||||||
setHeaderLabels(cols);
|
setHeaderLabels(cols);
|
||||||
|
|
||||||
|
for(int i=0;i<NUM_COLUMNS;i++){
|
||||||
|
if(!Columns[i])ColumnOrder[i]=100;
|
||||||
|
}
|
||||||
|
|
||||||
QMap<int,int> Order;
|
QMap<int,int> Order;
|
||||||
for(int i=NUM_COLUMNS-1;i>=0;i--)
|
for(int i=NUM_COLUMNS-1;i>=0;i--)
|
||||||
Order.insertMulti(ColumnOrder[i],i);
|
Order.insertMulti(ColumnOrder[i],i);
|
||||||
|
@ -463,6 +474,7 @@ int KeepassEntryView::logicalColIndex(int LstIndex){
|
||||||
int c=-1;
|
int c=-1;
|
||||||
for(int i=0;i<NUM_COLUMNS;i++){
|
for(int i=0;i<NUM_COLUMNS;i++){
|
||||||
if(Columns[i])c++;
|
if(Columns[i])c++;
|
||||||
|
if(i==10 && Columns[10] && ViewMode!=ShowSearchResults)c--;
|
||||||
if(i==LstIndex)return c;
|
if(i==LstIndex)return c;
|
||||||
}
|
}
|
||||||
Q_ASSERT(false);
|
Q_ASSERT(false);
|
||||||
|
@ -472,6 +484,13 @@ void KeepassEntryView::resizeColumns(){
|
||||||
AutoResizeColumns=false;
|
AutoResizeColumns=false;
|
||||||
int w=viewport()->width();
|
int w=viewport()->width();
|
||||||
int sum=0;
|
int sum=0;
|
||||||
|
|
||||||
|
for(int i=0;i<NUM_COLUMNS;i++){
|
||||||
|
// if(i==10) continue; //skip "Group" column
|
||||||
|
if(!Columns[i])ColumnSizes[i]=0;
|
||||||
|
if(Columns[i] && ColumnSizes[i]==0)ColumnSizes[i]=0.1f*(float)w;
|
||||||
|
}
|
||||||
|
|
||||||
for(int i=0;i<header()->count();i++){
|
for(int i=0;i<header()->count();i++){
|
||||||
sum+=ColumnSizes[columnListIndex(i)];
|
sum+=ColumnSizes[columnListIndex(i)];
|
||||||
}
|
}
|
||||||
|
@ -484,7 +503,6 @@ void KeepassEntryView::resizeColumns(){
|
||||||
if(i==header()->count()-1){
|
if(i==header()->count()-1){
|
||||||
NewSize+=(w-sum); // add rounding difference to the last column
|
NewSize+=(w-sum); // add rounding difference to the last column
|
||||||
}
|
}
|
||||||
//qDebug("i=%i lstIndex=%i NewSize=%f",i,lstIndex,NewSize);
|
|
||||||
header()->resizeSection(header()->logicalIndex(i),NewSize);
|
header()->resizeSection(header()->logicalIndex(i),NewSize);
|
||||||
ColumnSizes[lstIndex]=NewSize;
|
ColumnSizes[lstIndex]=NewSize;
|
||||||
}
|
}
|
||||||
|
@ -495,6 +513,7 @@ int KeepassEntryView::columnListIndex(int LogicalIndex){
|
||||||
int c=-1; int i=0;
|
int c=-1; int i=0;
|
||||||
for(i;i<NUM_COLUMNS;i++){
|
for(i;i<NUM_COLUMNS;i++){
|
||||||
if(Columns[i])c++;
|
if(Columns[i])c++;
|
||||||
|
if(i==10 && Columns[10] && ViewMode!=ShowSearchResults)c--;
|
||||||
if(c==LogicalIndex)break;
|
if(c==LogicalIndex)break;
|
||||||
}
|
}
|
||||||
return i;
|
return i;
|
||||||
|
@ -597,8 +616,9 @@ EntryViewItem::EntryViewItem(QTreeWidgetItem *parent, QTreeWidgetItem *preceding
|
||||||
|
|
||||||
|
|
||||||
bool EntryViewItem::operator<(const QTreeWidgetItem& other)const{
|
bool EntryViewItem::operator<(const QTreeWidgetItem& other)const{
|
||||||
int SortCol=treeWidget()->sortColumn();
|
int SortCol=treeWidget()->header()->sortIndicatorSection();
|
||||||
if(SortCol < 5 || SortCol==9 || SortCol==10){ //columns with string values (Title, Username, Password, URL, Comment, Group)
|
int ListIndex=((KeepassEntryView*)treeWidget())->columnListIndex(SortCol);
|
||||||
|
if(ListIndex < 5 || ListIndex==9 || ListIndex==10){ //columns with string values (Title, Username, Password, URL, Comment, Group)
|
||||||
if(QString::localeAwareCompare(text(SortCol),other.text(SortCol)) < 0)
|
if(QString::localeAwareCompare(text(SortCol),other.text(SortCol)) < 0)
|
||||||
return true;
|
return true;
|
||||||
else
|
else
|
||||||
|
|
|
@ -43,17 +43,17 @@ class KeepassEntryView:public QTreeWidget{
|
||||||
void showSearchResults();
|
void showSearchResults();
|
||||||
void showGroup(IGroupHandle* group);
|
void showGroup(IGroupHandle* group);
|
||||||
void updateColumns();
|
void updateColumns();
|
||||||
|
int columnListIndex(int LogicalIndex);
|
||||||
IDatabase* db;
|
IDatabase* db;
|
||||||
QList<EntryViewItem*>Items;
|
QList<EntryViewItem*>Items;
|
||||||
QList<IEntryHandle*> SearchResults;
|
QList<IEntryHandle*> SearchResults;
|
||||||
QMenu *ContextMenu;
|
QMenu *ContextMenu;
|
||||||
QVarLengthArray<bool>Columns;
|
QVarLengthArray<bool>Columns;
|
||||||
private:
|
private:
|
||||||
void setEntry(IEntryHandle* entry);
|
void setEntry(IEntryHandle* entry);
|
||||||
void updateEntry(EntryViewItem*);
|
void updateEntry(EntryViewItem*);
|
||||||
void editEntry(EntryViewItem*);
|
void editEntry(EntryViewItem*);
|
||||||
void createItems(QList<IEntryHandle*>& entries);
|
void createItems(QList<IEntryHandle*>& entries);
|
||||||
int columnListIndex(int LogicalIndex);
|
|
||||||
int logicalColIndex(int ListIndex);
|
int logicalColIndex(int ListIndex);
|
||||||
|
|
||||||
QClipboard* Clipboard;
|
QClipboard* Clipboard;
|
||||||
|
@ -68,6 +68,7 @@ class KeepassEntryView:public QTreeWidget{
|
||||||
EntryViewMode ViewMode;
|
EntryViewMode ViewMode;
|
||||||
QVarLengthArray<float>ColumnSizes;
|
QVarLengthArray<float>ColumnSizes;
|
||||||
QVarLengthArray<int>ColumnOrder;
|
QVarLengthArray<int>ColumnOrder;
|
||||||
|
float GroupColumnSize;
|
||||||
|
|
||||||
virtual void contextMenuEvent(QContextMenuEvent *event);
|
virtual void contextMenuEvent(QContextMenuEvent *event);
|
||||||
virtual void paintEvent(QPaintEvent* event);
|
virtual void paintEvent(QPaintEvent* event);
|
||||||
|
|
|
@ -307,7 +307,6 @@ void loadImages(){
|
||||||
bool small=true;
|
bool small=true;
|
||||||
QString ThemeDir=AppDir+"/../share/keepass/icons/nuvola/32x32";
|
QString ThemeDir=AppDir+"/../share/keepass/icons/nuvola/32x32";
|
||||||
|
|
||||||
|
|
||||||
QPixmap tmpImg;
|
QPixmap tmpImg;
|
||||||
|
|
||||||
//-----------------------
|
//-----------------------
|
||||||
|
|
|
@ -66,6 +66,7 @@ QDBusConnection* dbusCon;
|
||||||
|
|
||||||
Import_KeePassX_Xml import_KeePassX_Xml;
|
Import_KeePassX_Xml import_KeePassX_Xml;
|
||||||
Import_PwManager import_PwManager;
|
Import_PwManager import_PwManager;
|
||||||
|
Import_KWalletXml import_KWalletXml;
|
||||||
Export_Txt export_Txt;
|
Export_Txt export_Txt;
|
||||||
Export_KeePassX_Xml export_KeePassX_Xml;
|
Export_KeePassX_Xml export_KeePassX_Xml;
|
||||||
|
|
||||||
|
@ -288,6 +289,7 @@ void KeepassMainWindow::setupMenus(){
|
||||||
|
|
||||||
_add_import(import_KeePassX_Xml)
|
_add_import(import_KeePassX_Xml)
|
||||||
_add_import(import_PwManager)
|
_add_import(import_PwManager)
|
||||||
|
_add_import(import_KWalletXml)
|
||||||
_add_export(export_Txt);
|
_add_export(export_Txt);
|
||||||
_add_export(export_KeePassX_Xml);
|
_add_export(export_KeePassX_Xml);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue