X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/1e3aba5a02acd7670a4525ba9c0ce53b7e7e12de..e8167f6b3a83525a07c79e03917bad570a6c5c26:/services/api/app/models/collection.rb diff --git a/services/api/app/models/collection.rb b/services/api/app/models/collection.rb index 03e5e4ef44..620b74a96a 100644 --- a/services/api/app/models/collection.rb +++ b/services/api/app/models/collection.rb @@ -8,6 +8,10 @@ class Collection < ArvadosModel t.add :files end + api_accessible :with_data, extend: :user do |t| + t.add :manifest_text + end + def redundancy_status if redundancy_confirmed_as.nil? 'unconfirmed' @@ -33,14 +37,14 @@ class Collection < ArvadosModel self.uuid.gsub! /$/, '+' + self.manifest_text.length.to_s true else - errors.add :uuid, 'uuid does not match checksum of manifest_text' + errors.add :uuid, 'does not match checksum of manifest_text' false end elsif self.manifest_text - errors.add :uuid, 'checksum for manifest_text not supplied in uuid' + errors.add :uuid, 'not supplied (must match checksum of manifest_text)' false else - errors.add :manifest_text, 'manifest_text not supplied' + errors.add :manifest_text, 'not supplied' false end end @@ -61,8 +65,19 @@ class Collection < ArvadosModel @files = [] return end + + #normalized_manifest = "" + #IO.popen(['arv-normalize'], 'w+b') do |io| + # io.write manifest_text + # io.close_write + # while buf = io.read(2**20) + # normalized_manifest += buf + # end + #end + @data_size = 0 - @files = [] + tmp = {} + manifest_text.split("\n").each do |stream| toks = stream.split(" ") @@ -94,10 +109,38 @@ class Collection < ArvadosModel else $1.to_i(8).chr end end - @files << [stream, filename, re[2].to_i] + fn = stream + '/' + filename + i = re[2].to_i + if tmp[fn] + tmp[fn] += i + else + tmp[fn] = i + end end end end end + + @files = [] + tmp.each do |k, v| + re = k.match(/^(.+)\/(.+)/) + @files << [re[1], re[2], v] + end + end + + def self.normalize_uuid uuid + hash_part = nil + size_part = nil + uuid.split('+').each do |token| + if token.match /^[0-9a-f]{32,}$/ + raise "uuid #{uuid} has multiple hash parts" if hash_part + hash_part = token + elsif token.match /^\d+$/ + raise "uuid #{uuid} has multiple size parts" if size_part + size_part = token + end + end + raise "uuid #{uuid} has no hash part" if !hash_part + [hash_part, size_part].compact.join '+' end end