mirror of
https://github.com/nextcloud/desktop.git
synced 2024-11-28 11:48:56 +03:00
Add error category for http file lock error status 423.
It filters the error out of the list of blocking errors. It now shows up in the Activities and Notificattions list as a warning. Signed-off-by: Camila San <hello@camila.codes>
This commit is contained in:
parent
795c29d5bd
commit
bb7d330516
12 changed files with 40 additions and 5 deletions
|
@ -105,7 +105,8 @@ QVariant ActivityListModel::data(const QModelIndex &index, int role) const
|
||||||
} else if(a._status == SyncFileItem::SoftError
|
} else if(a._status == SyncFileItem::SoftError
|
||||||
|| a._status == SyncFileItem::FileIgnored
|
|| a._status == SyncFileItem::FileIgnored
|
||||||
|| a._status == SyncFileItem::Conflict
|
|| a._status == SyncFileItem::Conflict
|
||||||
|| a._status == SyncFileItem::Restoration){
|
|| a._status == SyncFileItem::Restoration
|
||||||
|
|| a._status == SyncFileItem::FileLocked){
|
||||||
return QIcon(QLatin1String(":/client/resources/state-warning.svg"));
|
return QIcon(QLatin1String(":/client/resources/state-warning.svg"));
|
||||||
}
|
}
|
||||||
return QIcon(QLatin1String(":/client/resources/state-sync.svg"));
|
return QIcon(QLatin1String(":/client/resources/state-sync.svg"));
|
||||||
|
|
|
@ -121,6 +121,11 @@ void ActivityWidget::slotProgressInfo(const QString &folder, const ProgressInfo
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(activity._status == SyncFileItem::FileLocked && !QFileInfo(f->path() + activity._file).exists()){
|
||||||
|
_model->removeActivityFromActivityList(activity);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if(activity._status == SyncFileItem::FileIgnored && !QFileInfo(f->path() + activity._file).exists()){
|
if(activity._status == SyncFileItem::FileIgnored && !QFileInfo(f->path() + activity._file).exists()){
|
||||||
_model->removeActivityFromActivityList(activity);
|
_model->removeActivityFromActivityList(activity);
|
||||||
|
|
|
@ -351,6 +351,10 @@ void Folder::showSyncResultPopup()
|
||||||
createGuiLog(_syncResult.firstItemError()->_file, LogStatusError, errorCount);
|
createGuiLog(_syncResult.firstItemError()->_file, LogStatusError, errorCount);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (int lockedCount = _syncResult.numLockedItems()) {
|
||||||
|
createGuiLog(_syncResult.firstItemLocked()->_file, LogStatusFileLocked, lockedCount);
|
||||||
|
}
|
||||||
|
|
||||||
qCInfo(lcFolder) << "Folder sync result: " << int(_syncResult.status());
|
qCInfo(lcFolder) << "Folder sync result: " << int(_syncResult.status());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -344,7 +344,8 @@ private:
|
||||||
LogStatusNew,
|
LogStatusNew,
|
||||||
LogStatusError,
|
LogStatusError,
|
||||||
LogStatusConflict,
|
LogStatusConflict,
|
||||||
LogStatusUpdated
|
LogStatusUpdated,
|
||||||
|
LogStatusFileLocked
|
||||||
};
|
};
|
||||||
|
|
||||||
void createGuiLog(const QString &filename, LogStatus status, int count,
|
void createGuiLog(const QString &filename, LogStatus status, int count,
|
||||||
|
|
|
@ -269,6 +269,7 @@ void PropagateItemJob::done(SyncFileItem::Status statusArg, const QString &error
|
||||||
case SyncFileItem::FileIgnored:
|
case SyncFileItem::FileIgnored:
|
||||||
case SyncFileItem::NoStatus:
|
case SyncFileItem::NoStatus:
|
||||||
case SyncFileItem::BlacklistedError:
|
case SyncFileItem::BlacklistedError:
|
||||||
|
case SyncFileItem::FileLocked:
|
||||||
// nothing
|
// nothing
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -93,7 +93,7 @@ inline SyncFileItem::Status classifyError(QNetworkReply::NetworkError nerror,
|
||||||
if (anotherSyncNeeded) {
|
if (anotherSyncNeeded) {
|
||||||
*anotherSyncNeeded = true;
|
*anotherSyncNeeded = true;
|
||||||
}
|
}
|
||||||
return SyncFileItem::SoftError;
|
return SyncFileItem::FileLocked;
|
||||||
}
|
}
|
||||||
|
|
||||||
return SyncFileItem::NormalError;
|
return SyncFileItem::NormalError;
|
||||||
|
|
|
@ -91,7 +91,8 @@ bool Progress::isWarningKind(SyncFileItem::Status kind)
|
||||||
return kind == SyncFileItem::SoftError || kind == SyncFileItem::NormalError
|
return kind == SyncFileItem::SoftError || kind == SyncFileItem::NormalError
|
||||||
|| kind == SyncFileItem::FatalError || kind == SyncFileItem::FileIgnored
|
|| kind == SyncFileItem::FatalError || kind == SyncFileItem::FileIgnored
|
||||||
|| kind == SyncFileItem::Conflict || kind == SyncFileItem::Restoration
|
|| kind == SyncFileItem::Conflict || kind == SyncFileItem::Restoration
|
||||||
|| kind == SyncFileItem::DetailError || kind == SyncFileItem::BlacklistedError;
|
|| kind == SyncFileItem::DetailError || kind == SyncFileItem::BlacklistedError
|
||||||
|
|| kind == SyncFileItem::FileLocked;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Progress::isIgnoredKind(SyncFileItem::Status kind)
|
bool Progress::isIgnoredKind(SyncFileItem::Status kind)
|
||||||
|
|
|
@ -571,6 +571,12 @@ void PropagateDownloadFile::slotGetFinished()
|
||||||
qCWarning(lcPropagateDownload) << "server replied 404, assuming file was deleted";
|
qCWarning(lcPropagateDownload) << "server replied 404, assuming file was deleted";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Getting a 423 means that the file is locked
|
||||||
|
const bool fileLocked = _item->_httpErrorCode == 423;
|
||||||
|
if (fileLocked) {
|
||||||
|
qCWarning(lcPropagateDownload) << "server replied 423, file is Locked";
|
||||||
|
}
|
||||||
|
|
||||||
// Don't keep the temporary file if it is empty or we
|
// Don't keep the temporary file if it is empty or we
|
||||||
// used a bad range header or the file's not on the server anymore.
|
// used a bad range header or the file's not on the server anymore.
|
||||||
if (_tmpFile.size() == 0 || badRangeHeader || fileNotFound) {
|
if (_tmpFile.size() == 0 || badRangeHeader || fileNotFound) {
|
||||||
|
|
|
@ -59,6 +59,7 @@ public:
|
||||||
Conflict,
|
Conflict,
|
||||||
|
|
||||||
FileIgnored, ///< The file is in the ignored list (or blacklisted with no retries left)
|
FileIgnored, ///< The file is in the ignored list (or blacklisted with no retries left)
|
||||||
|
FileLocked, ///< The file is locked
|
||||||
Restoration, ///< The file was restored because what should have been done was not allowed
|
Restoration, ///< The file was restored because what should have been done was not allowed
|
||||||
|
|
||||||
/** For errors that should only appear in the error view.
|
/** For errors that should only appear in the error view.
|
||||||
|
|
|
@ -105,7 +105,8 @@ static inline bool showWarningInSocketApi(const SyncFileItem &item)
|
||||||
return item._instruction == CSYNC_INSTRUCTION_IGNORE
|
return item._instruction == CSYNC_INSTRUCTION_IGNORE
|
||||||
|| status == SyncFileItem::FileIgnored
|
|| status == SyncFileItem::FileIgnored
|
||||||
|| status == SyncFileItem::Conflict
|
|| status == SyncFileItem::Conflict
|
||||||
|| status == SyncFileItem::Restoration;
|
|| status == SyncFileItem::Restoration
|
||||||
|
|| status == SyncFileItem::FileLocked;
|
||||||
}
|
}
|
||||||
|
|
||||||
SyncFileStatusTracker::SyncFileStatusTracker(SyncEngine *syncEngine)
|
SyncFileStatusTracker::SyncFileStatusTracker(SyncEngine *syncEngine)
|
||||||
|
|
|
@ -28,6 +28,7 @@ SyncResult::SyncResult()
|
||||||
, _numNewConflictItems(0)
|
, _numNewConflictItems(0)
|
||||||
, _numOldConflictItems(0)
|
, _numOldConflictItems(0)
|
||||||
, _numErrorItems(0)
|
, _numErrorItems(0)
|
||||||
|
, _numLockedItems(0)
|
||||||
|
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -139,6 +140,13 @@ void SyncResult::processCompletedItem(const SyncFileItemPtr &item)
|
||||||
_folderStructureWasChanged = true;
|
_folderStructureWasChanged = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(item->_status == SyncFileItem::FileLocked){
|
||||||
|
_numLockedItems++;
|
||||||
|
if (!_firstItemLocked) {
|
||||||
|
_firstItemLocked = item;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Process the item to the gui
|
// Process the item to the gui
|
||||||
if (item->_status == SyncFileItem::FatalError || item->_status == SyncFileItem::NormalError) {
|
if (item->_status == SyncFileItem::FatalError || item->_status == SyncFileItem::NormalError) {
|
||||||
//: this displays an error string (%2) for a file %1
|
//: this displays an error string (%2) for a file %1
|
||||||
|
|
|
@ -72,12 +72,16 @@ public:
|
||||||
int numErrorItems() const { return _numErrorItems; }
|
int numErrorItems() const { return _numErrorItems; }
|
||||||
bool hasUnresolvedConflicts() const { return _numNewConflictItems + _numOldConflictItems > 0; }
|
bool hasUnresolvedConflicts() const { return _numNewConflictItems + _numOldConflictItems > 0; }
|
||||||
|
|
||||||
|
int numLockedItems() const { return _numLockedItems; }
|
||||||
|
bool hasLockedFiles() const { return _numLockedItems > 0; }
|
||||||
|
|
||||||
const SyncFileItemPtr &firstItemNew() const { return _firstItemNew; }
|
const SyncFileItemPtr &firstItemNew() const { return _firstItemNew; }
|
||||||
const SyncFileItemPtr &firstItemDeleted() const { return _firstItemDeleted; }
|
const SyncFileItemPtr &firstItemDeleted() const { return _firstItemDeleted; }
|
||||||
const SyncFileItemPtr &firstItemUpdated() const { return _firstItemUpdated; }
|
const SyncFileItemPtr &firstItemUpdated() const { return _firstItemUpdated; }
|
||||||
const SyncFileItemPtr &firstItemRenamed() const { return _firstItemRenamed; }
|
const SyncFileItemPtr &firstItemRenamed() const { return _firstItemRenamed; }
|
||||||
const SyncFileItemPtr &firstNewConflictItem() const { return _firstNewConflictItem; }
|
const SyncFileItemPtr &firstNewConflictItem() const { return _firstNewConflictItem; }
|
||||||
const SyncFileItemPtr &firstItemError() const { return _firstItemError; }
|
const SyncFileItemPtr &firstItemError() const { return _firstItemError; }
|
||||||
|
const SyncFileItemPtr &firstItemLocked() const { return _firstItemLocked; }
|
||||||
|
|
||||||
void processCompletedItem(const SyncFileItemPtr &item);
|
void processCompletedItem(const SyncFileItemPtr &item);
|
||||||
|
|
||||||
|
@ -101,6 +105,7 @@ private:
|
||||||
int _numNewConflictItems;
|
int _numNewConflictItems;
|
||||||
int _numOldConflictItems;
|
int _numOldConflictItems;
|
||||||
int _numErrorItems;
|
int _numErrorItems;
|
||||||
|
int _numLockedItems;
|
||||||
|
|
||||||
SyncFileItemPtr _firstItemNew;
|
SyncFileItemPtr _firstItemNew;
|
||||||
SyncFileItemPtr _firstItemDeleted;
|
SyncFileItemPtr _firstItemDeleted;
|
||||||
|
@ -108,6 +113,7 @@ private:
|
||||||
SyncFileItemPtr _firstItemRenamed;
|
SyncFileItemPtr _firstItemRenamed;
|
||||||
SyncFileItemPtr _firstNewConflictItem;
|
SyncFileItemPtr _firstNewConflictItem;
|
||||||
SyncFileItemPtr _firstItemError;
|
SyncFileItemPtr _firstItemError;
|
||||||
|
SyncFileItemPtr _firstItemLocked;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue