Merge pull request #5330 from si458/fix-webdav-upload

Fix webdav upload
This commit is contained in:
Ylian Saint-Hilaire 2023-09-09 23:02:04 -07:00 committed by GitHub
commit a3dfc30607
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 31 additions and 33 deletions

36
db.js
View File

@ -3071,39 +3071,37 @@ module.exports.CreateDB = function (parent, func) {
// Upload to the WebDAV folder // Upload to the WebDAV folder
function performWebDavUpload(client, filepath) { function performWebDavUpload(client, filepath) {
require('fs').stat(filepath, function(err,stat){
var fileStream = require('fs').createReadStream(filepath); var fileStream = require('fs').createReadStream(filepath);
fileStream.on('close', function () { if (func) { func('WebDAV upload completed'); } }) fileStream.on('close', function () { if (func) { func('WebDAV upload completed'); } })
fileStream.on('error', function (err) { if (func) { func('WebDAV (fileUpload) error: ' + err); } }) fileStream.on('error', function (err) { if (func) { func('WebDAV (fileUpload) error: ' + err); } })
fileStream.pipe(client.createWriteStream('/' + webdavfolderName + '/' + require('path').basename(filepath))); fileStream.pipe(client.createWriteStream('/' + webdavfolderName + '/' + require('path').basename(filepath), { headers: { "Content-Length": stat.size } }));
if (func) { func('Uploading using WebDAV...'); } if (func) { func('Uploading using WebDAV...'); }
});
} }
if (func) { func('Attempting WebDAV upload...'); } if (func) { func('Attempting WebDAV upload...'); }
const { createClient } = require('webdav'); const { createClient } = require('webdav');
const client = createClient(parent.config.settings.autobackup.webdav.url, { username: parent.config.settings.autobackup.webdav.username, password: parent.config.settings.autobackup.webdav.password }); const client = createClient(parent.config.settings.autobackup.webdav.url, {
var directoryItems = client.getDirectoryContents('/'); username: parent.config.settings.autobackup.webdav.username,
directoryItems.then( password: parent.config.settings.autobackup.webdav.password,
function (files) { maxContentLength: Infinity,
var folderFound = false; maxBodyLength: Infinity
for (var i in files) { if ((files[i].basename == webdavfolderName) && (files[i].type == 'directory')) { folderFound = true; } } });
if (folderFound == false) { client.exists(webdavfolderName).then(function(a){
client.createDirectory(webdavfolderName).then(function (a) { if(a){
if (a.statusText == 'Created') { performWebDavCleanup(client);
performWebDavUpload(client, filename);
}else{
client.createDirectory(webdavfolderName, {recursive: true}).then(function (a) {
if (func) { func('WebDAV folder created'); } if (func) { func('WebDAV folder created'); }
performWebDavUpload(client, filename); performWebDavUpload(client, filename);
} else {
if (func) { func('WebDAV (createDirectory) status: ' + a.statusText); }
}
}).catch(function (err) { }).catch(function (err) {
if (func) { func('WebDAV (createDirectory) error: ' + err); } if (func) { func('WebDAV (createDirectory) error: ' + err); }
}); });
} else {
performWebDavCleanup(client);
performWebDavUpload(client, filename);
} }
} }).catch(function (err) {
).catch(function (err) { if (func) { func('WebDAV (exists) error: ' + err); }
if (func) { func('WebDAV (getDirectoryContents) error: ' + err); }
}); });
} }

View File

@ -4023,12 +4023,12 @@ function mainStart() {
// Setup encrypted zip support if needed // Setup encrypted zip support if needed
if (config.settings.autobackup && config.settings.autobackup.zippassword) { if (config.settings.autobackup && config.settings.autobackup.zippassword) {
modules.push('archiver-zip-encrypted'); modules.push('archiver-zip-encrypted');
}
// Enable Google Drive Support // Enable Google Drive Support
if (typeof config.settings.autobackup.googledrive == 'object') { modules.push('googleapis'); } if (typeof config.settings.autobackup.googledrive == 'object') { modules.push('googleapis'); }
// Enable WebDAV Support // Enable WebDAV Support
if (typeof config.settings.autobackup.webdav == 'object') { if (typeof config.settings.autobackup.webdav == 'object') {
if ((typeof config.settings.autobackup.webdav.url != 'string') || (typeof config.settings.autobackup.webdav.username != 'string') || (typeof config.settings.autobackup.webdav.password != 'string')) { addServerWarning("Missing WebDAV parameters.", 2, null, !args.launch); } else { modules.push('webdav@4.11.2'); } if ((typeof config.settings.autobackup.webdav.url != 'string') || (typeof config.settings.autobackup.webdav.username != 'string') || (typeof config.settings.autobackup.webdav.password != 'string')) { addServerWarning("Missing WebDAV parameters.", 2, null, !args.launch); } else { modules.push('webdav@4.11.3'); }
}
} }
// Setup common password blocking // Setup common password blocking