2018-11-18 11:00:15 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
module Ci
|
|
|
|
module BuildTraceChunks
|
|
|
|
class Fog
|
|
|
|
def available?
|
|
|
|
object_store.enabled
|
|
|
|
end
|
|
|
|
|
|
|
|
def data(model)
|
2021-01-03 14:25:43 +05:30
|
|
|
files.get(key(model))&.body
|
2020-10-24 23:57:45 +05:30
|
|
|
rescue Excon::Error::NotFound
|
|
|
|
# If the object does not exist in the object storage, this method returns nil.
|
2018-11-08 19:23:39 +05:30
|
|
|
end
|
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
def set_data(model, new_data)
|
2021-03-11 19:13:27 +05:30
|
|
|
files.create(create_attributes(model, new_data))
|
2020-10-24 23:57:45 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def append_data(model, new_data, offset)
|
|
|
|
if offset > 0
|
|
|
|
truncated_data = data(model).to_s.byteslice(0, offset)
|
|
|
|
new_data = truncated_data + new_data
|
|
|
|
end
|
|
|
|
|
|
|
|
set_data(model, new_data)
|
|
|
|
new_data.bytesize
|
|
|
|
end
|
|
|
|
|
|
|
|
def size(model)
|
|
|
|
data(model).to_s.bytesize
|
2018-11-08 19:23:39 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def delete_data(model)
|
|
|
|
delete_keys([[model.build_id, model.chunk_index]])
|
|
|
|
end
|
|
|
|
|
|
|
|
def keys(relation)
|
|
|
|
return [] unless available?
|
|
|
|
|
|
|
|
relation.pluck(:build_id, :chunk_index)
|
|
|
|
end
|
|
|
|
|
|
|
|
def delete_keys(keys)
|
|
|
|
keys.each do |key|
|
2021-01-03 14:25:43 +05:30
|
|
|
files.destroy(key_raw(*key))
|
2018-11-08 19:23:39 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def key(model)
|
|
|
|
key_raw(model.build_id, model.chunk_index)
|
|
|
|
end
|
|
|
|
|
2021-02-22 17:27:13 +05:30
|
|
|
def create_attributes(model, new_data)
|
|
|
|
{
|
|
|
|
key: key(model),
|
|
|
|
body: new_data
|
|
|
|
}.merge(object_store_config.fog_attributes)
|
|
|
|
end
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
def key_raw(build_id, chunk_index)
|
|
|
|
"tmp/builds/#{build_id.to_i}/chunks/#{chunk_index.to_i}.log"
|
|
|
|
end
|
|
|
|
|
|
|
|
def bucket_name
|
|
|
|
return unless available?
|
|
|
|
|
|
|
|
object_store.remote_directory
|
|
|
|
end
|
|
|
|
|
|
|
|
def connection
|
|
|
|
return unless available?
|
|
|
|
|
|
|
|
@connection ||= ::Fog::Storage.new(object_store.connection.to_hash.deep_symbolize_keys)
|
|
|
|
end
|
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
def fog_directory
|
|
|
|
@fog_directory ||= connection.directories.new(key: bucket_name)
|
|
|
|
end
|
|
|
|
|
|
|
|
def files
|
|
|
|
@files ||= fog_directory.files
|
|
|
|
end
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
def object_store
|
|
|
|
Gitlab.config.artifacts.object_store
|
|
|
|
end
|
2021-02-22 17:27:13 +05:30
|
|
|
|
|
|
|
def object_store_raw_config
|
|
|
|
object_store
|
|
|
|
end
|
|
|
|
|
|
|
|
def object_store_config
|
|
|
|
@object_store_config ||= ::ObjectStorage::Config.new(object_store_raw_config)
|
|
|
|
end
|
2018-11-08 19:23:39 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|