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