Ho questo codice, che scrive un file zip su disco, lo legge di nuovo, arrivi agli S3, quindi elimina il file:Rubyzip: Esporta il file zip direttamente su S3 senza scrivere tmpfile su disco?
compressed_file = some_temp_path
Zip::ZipOutputStream.open(compressed_file) do |zos|
some_file_list.each do |file|
zos.put_next_entry(file.some_title)
zos.print IO.read(file.path)
end
end # Write zip file
s3 = Aws::S3.new(S3_KEY, S3_SECRET)
bucket = Aws::S3::Bucket.create(s3, S3_BUCKET)
bucket.put("#{BUCKET_PATH}/archive.zip", IO.read(compressed_file), {}, 'authenticated-read')
File.delete(compressed_file)
Questo codice funziona già, ma quello che voglio è quello di non creare la zip file, per salvare alcuni passaggi. Mi chiedevo se c'è un modo per esportare i dati zipfile direttamente su s3 senza dover prima creare un file tmp, leggerlo di nuovo, quindi cancellarlo?
Che cos'è 'some_file_list'? – Trip
Sto immaginando qualcosa di simile a "some_file_list = Zip :: ZipFile.open (zip_file)" – Trip
Potrebbe essere. Per me, stavo leggendo i miei file da S3. – index