summaryrefslogtreecommitdiffstats
path: root/publickeyimportdialog.h
blob: c6014cca47519b93602dc803338184ce3e385f43 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#ifndef PUBLICKEYIMPORTDIALOG_H
#define PUBLICKEYIMPORTDIALOG_H

#include <QAbstractButton>
#include <QDebug>
#include <QDialog>
#include <QFileDialog>
#include <QListWidgetItem>

#include "crypt/hybridcrypt.h"

namespace Ui {
class PublicKeyImportDialog;
}
/**
 * @brief Diese Klasse fordert vom Benutze
 */
class PublicKeyImportDialog : public QDialog
{
    Q_OBJECT

public:
    /**
     * @brief Erstellt das Objekt für das UserInterface
     * und für den eigenen Schlüssel und füllt ihn mit Daten.
     * @param parent Das Elternfenster dieses Objektes.
     */
    explicit PublicKeyImportDialog(QWidget *parent = 0);    
    ~PublicKeyImportDialog();
    /**
     * @brief Gibt eine Liste von Öffentichen Schlüsseln zurück.
     * @return Eine Liste von Öffentichen Schlüsseln.
     */
    QVector<QString> getFielListPublicKey() const;

    /**
     * @brief gibt den Filenamen zurück.
     * @return Den Filename in den die Datei geschreiben werden soll.
     */
    QString getOutFileName() const;

private slots:
    /**
     * @brief Slot Implementierung für Zurücksetzenbutton in .
     *
     * @param button Button der geklickt wurde.
     */
    void on_buttonBox_clicked(QAbstractButton *button);

    /**
     * @brief Solt Implementierung für Löschenbutton.
     * Löscht alle ausgewlten Elemente aus der ListWidget.
     */
    void on_pushButtonDelete_clicked();
    /**
     * @brief Solt Implementierung für Hinzufügenbutton.
     * Fügt ein Element in das ListWidget und in den m_FileListPublicKey Vektor ein.
     */
    void on_pushButtonAdd_clicked();


private:
    /**
     * @brief Objekt der GUI.
     */
    Ui::PublicKeyImportDialog *ui;
    /**
     * @brief Liste von Datei name der Öffentlichen Schlüsseldatein.
     */
    QVector<QString> m_FileListPublicKey;
    /**
     * @brief Dateiname in den die Entschlüsselte Datei gescheiben werden soll.
     */
    QString m_FileName;
    /**
     * @brief Speichert den Item des Eigenen Schlüssels.
     */
    QListWidgetItem *m_OneKey;

    // QDialog interface
public slots:
    /**
     * @brief Slot Implement für den Speicherbutton Überladendemethode von QWidget.
     */
    void accept();
};

#endif // PUBLICKEYIMPORTDIALOG_H