-
Notifications
You must be signed in to change notification settings - Fork 919
Expand file tree
/
Copy pathupdatee2eefolderusersmetadatajob.h
More file actions
111 lines (92 loc) · 4.26 KB
/
updatee2eefolderusersmetadatajob.h
File metadata and controls
111 lines (92 loc) · 4.26 KB
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*
* SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: GPL-2.0-or-later
*/
#pragma once
#include "accountfwd.h"
#include "encryptedfoldermetadatahandler.h" //NOTE: Forward declarion is not gonna work because of OWNCLOUDSYNC_EXPORT for UpdateE2eeFolderUsersMetadataJob
#include "gui/sharemanager.h"
#include "syncfileitem.h"
#include "gui/sharee.h"
#include <QHash>
#include <QMutex>
#include <QObject>
#include <QScopedPointer>
#include <QString>
class QSslCertificate;
namespace OCC
{
class SyncJournalDb;
class OWNCLOUDSYNC_EXPORT UpdateE2eeFolderUsersMetadataJob : public QObject
{
Q_OBJECT
public:
enum Operation { Invalid = -1, Add = 0, Remove, ReEncrypt };
struct UserData {
ShareePtr sharee;
Share::Permissions desiredPermissions;
QString password;
};
explicit UpdateE2eeFolderUsersMetadataJob(const AccountPtr &account,
SyncJournalDb *journalDb,
const QString &syncFolderRemotePath,
const Operation operation,
const QString &fullRemotePath = {},
const QString &folderUserId = {},
const QString &folderUserDisplayName = {},
const QSslCertificate &certificate = QSslCertificate{},
QObject *parent = nullptr);
~UpdateE2eeFolderUsersMetadataJob() override = default;
public:
[[nodiscard]] const QString &path() const;
[[nodiscard]] const UserData &userData() const;
[[nodiscard]] SyncFileItem::EncryptionStatus encryptionStatus() const;
[[nodiscard]] const QByteArray folderToken() const;
void unlockFolder(const EncryptedFolderMetadataHandler::UnlockFolderWithResult result);
public slots:
void start(const bool keepLock = false);
void setUserData(const OCC::UpdateE2eeFolderUsersMetadataJob::UserData &userData);
void setFolderToken(const QByteArray &folderToken);
void setMetadataKeyForEncryption(const QByteArray &metadataKey);
void setMetadataKeyForDecryption(const QByteArray &metadataKey);
void setKeyChecksums(const QSet<QByteArray> &keyChecksums);
void setSubJobSyncItems(const QHash<QString, OCC::SyncFileItemPtr> &subJobSyncItems);
private:
void scheduleSubJobs();
void startUpdate();
void subJobsFinished(bool success);
private slots:
void slotStartE2eeMetadataJobs();
void slotFetchMetadataJobFinished(int statusCode, const QString &message);
void slotSubJobFinished(int code, const QString &message = {});
void slotFolderUnlocked(const QByteArray &folderId, int httpStatus);
void slotUpdateMetadataFinished(int code, const QString &message = {});
void slotCertificatesFetchedFromServer(const QHash<QString, OCC::NextcloudSslCertificate> &results);
void slotCertificateFetchedFromKeychain(const QSslCertificate &certificate);
private: signals:
void certificateReady();
void finished(int code, const QString &message = {});
void folderUnlocked();
private:
AccountPtr _account;
QPointer<SyncJournalDb> _journalDb;
QString _syncFolderRemotePath;
Operation _operation = Invalid;
QString _fullRemotePath;
QString _folderUserId;
QString _folderUserDisplayName;
QSslCertificate _folderUserCertificate;
QByteArray _folderToken;
// needed when re-encrypting nested folders' metadata after top-level folder's metadata has changed
QByteArray _metadataKeyForEncryption;
QByteArray _metadataKeyForDecryption;
QSet<QByteArray> _keyChecksums;
//-------------------------------------------------------------------------------------------------
QSet<UpdateE2eeFolderUsersMetadataJob *> _subJobs;
UserData _userData; // share info, etc.
QHash<QString, SyncFileItemPtr> _subJobSyncItems; //used when migrating to update corresponding SyncFileItem(s) for nested folders, such that records in db will get updated when propagate item job is finalized
QMutex _subJobSyncItemsMutex;
QScopedPointer<EncryptedFolderMetadataHandler> _encryptedFolderMetadataHandler;
bool _keepLock = false;
};
}