электрона. Скажем myapp.exe.
Настроил обновление с использованием squirrel.
Разместил на своём хостинге https://myserver/download/latest/ необходимые файлы для автообновления.
Как я понял это:
myapp-2.0.0-full.nupkg,
RELEASE (без расширения)
Setup.exe
Они все автоматически создаются при сборке. Если открыть файл RELEASE (без расширения) через текстовый редактор, то там вот примерно такой текст: “D120EF45A371551596E5B0628722AD6368BA8391 myapp-2.0.0-full.nupkg 448403423”
Всё работает отлично. Раз в 30 секунд autoUpdater.checkForUpdates(); проверяет по этому урлу (https://myserver/download/latest/) наличие файла RELEASE (без расширения), и если он есть - запускает процесс автообновления.
Но я решил настроить для автообновлений electron-release-server. Поменял путь для проверки обновления с https://myserver/download/latest/ на http://localhost/download/latest/, так как пока для тестов собрался брать обновления из electron-release-server.
Настроил бд, запустил сервер, перешёл на http://localhost/admin/ и создал там Flavor с именем /download/latest/
Загрузил в этот Flavor файлы myapp-2.0.0-full.nupkg и Setup.exe.
Но вот RELEASE (без расширения) никак не хочет загружаться. А, как я понимаю, для старта автообновления нужен именно он.
Когда я нажимаю на "выберите файл" и перехожу в папку на компьютере, где у меня лежит нужный релиз, файл RELEASE вообще не отображается, так как доступны для загрузки файлы только формата .dmg, .zip, .deb, .exe, .nupkg, .blockmap. Я меняю на "все файлы", то тогда файл RELEASE становится виден, но при попытке его загрузить пишет вот такую ошибку "Unable to Create Asset An Unkown Error Occurred.
Пробовал загружать вместо RELEASE (без расширения) RELEASE.txt, RELEASE.json, но это не работает.
Судя по логам, ожидается именно RELEASES без всякого расширения:
[16.02.24 12:02:32] warn: IEnableLogger: Failed to download url: http://localhost/download/latest/RELEASES?id=myapp&localVersion=2.0.0&arch=amd64: System.Net.WebException: Удаленный сервер возвратил ошибку: (404) Не найден.
в System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)
Подскажите, пожалуйста, куда копать?
в сторону кода electron-release-server
Да, я пробовал. Закомментировал вот эту часть: uploadedFile.filename === 'RELEASES' (вообще непонятно зачем она. Заменил filetype: fileExt, на fileExt || '' чтобы fileExt мог быть в том числе и пустым. Но всё равно загрузить без расширения файл RELEASE не удаётся 🥲 req.file('file').upload(sails.config.files, function whenDone(err, uploadedFiles) { if (err) { return res.negotiate(err); } // If an unexpected number of files were uploaded, respond with an // error. if (uploadedFiles.length !== 1) { return res.badRequest('No file was uploaded'); } var uploadedFile = uploadedFiles[0]; console.log('uploadedFile.filename', uploadedFile.filename); console.log('uploadedFile', uploadedFile.filename); // if (uploadedFile.filename === 'RELEASES') { // return res.badRequest( // 'The RELEASES file should not be uploaded since the release server will generate at request time'); // } var fileExt = path.extname(uploadedFile.filename); console.log('fileExt', fileExt); sails.log.debug('Creating asset with name', data.name || uploadedFile.filename); var hashPromise; if (fileExt === '.nupkg') { // Calculate the hash of the file, as it is necessary for windows // files hashPromise = AssetService.getHash(uploadedFile.fd); } else if (fileExt === '.exe' || fileExt === '.zip') { hashPromise = AssetService.getHash( uploadedFile.fd, "sha512", "base64" ); } else { hashPromise = Promise.resolve(''); } hashPromise .then(function(fileHash) { var newAsset = _.merge({ name: uploadedFile.filename, hash: fileHash, filetype: fileExt || '', fd: uploadedFile.fd, size: uploadedFile.size }, data); // Due to an API change in Sails/Waterline, the primary key values must be specified directly.= newAsset.version = newAsset.version.id; const delta = newAsset.name && newAsset.name.toLowerCase().includes('-delta') ? 'delta_' : ''; newAsset.id = `${newAsset.version}_${newAsset.platform}_${delta}${newAsset.filetype.replace(/\./g, '')}`; // Create new instance of model using data from params Asset .create(newAsset) .exec(function created(err, newInstance) { // Differentiate between waterline-originated validation errors // and serious underlying issues. Respond with badRequest if a // validation error is encountered, w/ validation info. if (err) return res.negotiate(err); // If we have the pubsub hook, use the model class's publish // method to notify all subscribers about the created item. if (req._sails.hooks.pubsub) { if (req.isSocket) { Asset.subscribe(req, newInstance); Asset.introduce(newInstance); } Asset.publish([newInstance.id], { verb: 'created', id: newInstance.id, data: newInstance }, !req.options.mirror && req); } // Send JSONP-friendly response if it's supported res.ok(newInstance); }); }) .catch(res.negotiate); });
Обсуждают сегодня