mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-16 17:57:08 -05:00
87 lines
3.2 KiB
C++
87 lines
3.2 KiB
C++
/*
|
|
* Copyright (C) 2019 KeePassXC Team <team@keepassxc.org>
|
|
*
|
|
* 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, either version 2 or (at your option)
|
|
* version 3 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, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "AttachmentImport.h"
|
|
|
|
#include "Utils.h"
|
|
#include "core/Global.h"
|
|
#include "core/Group.h"
|
|
|
|
#include <QCommandLineParser>
|
|
#include <QFile>
|
|
|
|
const QCommandLineOption AttachmentImport::ForceOption =
|
|
QCommandLineOption(QStringList() << "f" << "force", QObject::tr("Overwrite existing attachments."));
|
|
|
|
AttachmentImport::AttachmentImport()
|
|
{
|
|
name = QString("attachment-import");
|
|
description = QObject::tr("Imports an attachment to an entry.");
|
|
options.append(AttachmentImport::ForceOption);
|
|
positionalArguments.append({QString("entry"), QObject::tr("Path of the entry."), QString("")});
|
|
positionalArguments.append(
|
|
{QString("attachment-name"), QObject::tr("Name of the attachment to be added."), QString("")});
|
|
positionalArguments.append(
|
|
{QString("import-file"), QObject::tr("Path of the attachment to be imported."), QString("")});
|
|
}
|
|
|
|
int AttachmentImport::executeWithDatabase(QSharedPointer<Database> database, QSharedPointer<QCommandLineParser> parser)
|
|
{
|
|
auto& out = parser->isSet(Command::QuietOption) ? Utils::DEVNULL : Utils::STDOUT;
|
|
auto& err = Utils::STDERR;
|
|
|
|
auto args = parser->positionalArguments();
|
|
auto entryPath = args.at(1);
|
|
|
|
auto entry = database->rootGroup()->findEntryByPath(entryPath);
|
|
if (!entry) {
|
|
err << QObject::tr("Could not find entry with path %1.").arg(entryPath) << Qt::endl;
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
auto attachmentName = args.at(2);
|
|
|
|
auto attachments = entry->attachments();
|
|
if (attachments->hasKey(attachmentName) && !parser->isSet(AttachmentImport::ForceOption)) {
|
|
err << QObject::tr("Attachment %1 already exists for entry %2.").arg(attachmentName, entryPath) << Qt::endl;
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
auto importFileName = args.at(3);
|
|
|
|
QFile importFile(importFileName);
|
|
if (!importFile.open(QIODevice::ReadOnly)) {
|
|
err << QObject::tr("Could not open attachment file %1.").arg(importFileName) << Qt::endl;
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
entry->beginUpdate();
|
|
attachments->set(attachmentName, importFile.readAll());
|
|
entry->endUpdate();
|
|
|
|
QString errorMessage;
|
|
if (!database->save(Database::Atomic, {}, &errorMessage)) {
|
|
err << QObject::tr("Writing the database failed %1.").arg(errorMessage) << Qt::endl;
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
out << QObject::tr("Successfully imported attachment %1 as %2 to entry %3.")
|
|
.arg(importFileName, attachmentName, entryPath)
|
|
<< Qt::endl;
|
|
return EXIT_SUCCESS;
|
|
}
|