Загрузка прогресса в Google Drive

В моем приложении Meteor server я загружаю файл с Google Drive, используя этот код,

var dest = fs.createWriteStream('/data/'+data.name);
        drive.files.get({
           fileId: data.id,
           alt: 'media',
           auth: jwtClient
        })
        .on('end', Meteor.bindEnvironment(function() {

        }))
        .on('error', function(err) {
          console.log('Error during download', err);
        })
        .pipe(dest);

Как я могу получить прогресс загрузки? Например, я хочу каждые 30 секунд отображать ход загрузки с помощью console.log()

Могу ли я использовать.on('data')? Я использую google drive nodejs v3, предоставленный Google.

1 ответ

Вы можете получить метаданные файла (id, name, size) из drive.files.list с именем файла, затем вы можете скачать файл.

Используйте Node.js Quickstart для Google Drive для аутентификации.

Я использую прогресс-поток для измерения% полученных данных.

var callAfterDownload = function (fileName, callback) {
  drive.files.list({
    auth: oauth2Client,
    pageSize: 1,
    q: 'name=\'' + fileName + '\'',
    fields: 'nextPageToken, files(id, name, size)'
  }, function (err, response) {
    if (err) {
      console.log('The API returned an error: ' + err)
      callback(['Error while download'])
    } else {
      var files = response.files
      //when only one file is matched we will download
      if (files.length === 1) {

        var file = files.pop()
        console.log('%s (%s)', file.name, file.id)
        var dest = fs.createWriteStream(file.name)
        var progress = Progress({time:100, length: file.size})

        //downloading matched file from drive
        drive.files.get({
          auth: oauth2Client,
          fileId: file.id,
          alt: 'media'
        }).on('error', function (err) {
          console.log('Error during download', err)
          callback(['Error while download'])
        }).pipe(progress).pipe(dest)

        //checking progress of file
        progress.on('progress', function(progress) {
          console.log('download completed ' +progress.percentage.toFixed(2) + '%')
        });

        //when write stream has finally written to file
        dest.on('finish', callback)

      } else {
        console.log('EXITING......More than one/no file exist with same name, make sure you have unique file name.')
        callback()
      }
    }
  })
}


function downloadDriveFile () {
  var fileName = 'testfile.doc'
  callAfterDownload(fileName, function (err) {
    if(err) throw err
    //your logic to do anything with the file
  })
}

downloadDriveFile();
Другие вопросы по тегам