Skip to content

Commit

Permalink
Handle --upload-only & --remove-source-files for upload session resum…
Browse files Browse the repository at this point in the history
…ption

* Handle --upload-only & --remove-source-files for upload session resumption
  • Loading branch information
abraunegg committed Nov 9, 2023
1 parent bcc77b7 commit 5fbfc49
Showing 1 changed file with 22 additions and 2 deletions.
24 changes: 22 additions & 2 deletions src/sync.d
Original file line number Diff line number Diff line change
Expand Up @@ -7260,8 +7260,28 @@ class SyncEngine {
// Was the response from the OneDrive API a valid JSON item?
if (uploadResponse.type() == JSONType.object) {
// A valid JSON object was returned - session resumption upload sucessful
// Save JSON item in database
saveItem(uploadResponse);

// Are we in an --upload-only & --remove-source-files scenario?
// Use actual config values as we are doing an upload session recovery
if (localDeleteAfterUpload) {
// Log that we are deleting a local item
log.log("Removing local file as --upload-only & --remove-source-files configured");
// are we in a --dry-run scenario?
if (!dryRun) {
// No --dry-run ... process local file delete
// Only perform the delete if we have a valid file path
if (exists(jsonItemToResume["localPath"].str)) {
// file exists
log.vdebug("Removing local file: ", jsonItemToResume["localPath"].str);
safeRemove(jsonItemToResume["localPath"].str);
}
}
// as file is removed, we have nothing to add to the local database
log.vdebug("Skipping adding to database as --upload-only & --remove-source-files configured");
} else {
// Save JSON item in database
saveItem(uploadResponse);
}
} else {
// No valid response was returned
writeln("CODING TO DO: what to do when session upload resumption JSON data is not valid ... nothing ? error message ?");
Expand Down

0 comments on commit 5fbfc49

Please sign in to comment.