module NexusCli::N3Metadata
Public Class Methods
Parses the regular custom metadata xml into a hash containing only the custom metadata.
# File lib/nexus_cli/n3_metadata.rb, line 44 def convert_result_to_hash(custom_metadata) request = {} document = REXML::Document.new(custom_metadata) REXML::XPath.each(document, "//customMetadataResponse/data/customMetadata[namespace=\"urn:nexus/user#\"]") do |row| request[row.elements["key"].text.strip] = row.elements["value"].text.strip end request end
Parses the regular custom metadata xml into a simpler format containing only the custom metadata.
# File lib/nexus_cli/n3_metadata.rb, line 29 def convert_result_to_simple_xml(custom_metadata) request = [] document = REXML::Document.new(custom_metadata) REXML::XPath.each(document, "//customMetadataResponse/data/customMetadata[namespace=\"urn:nexus/user#\"]") do |row| request.push(create_tag(row.elements["key"].text.strip, row.elements["value"].text.strip)) end formatter = REXML::Formatters::Pretty.new(4) formatter.compact = true document = REXML::Document.new("<artifact-resolution><data>#{request.join}</data></artifact-resolution>") out = "" formatter.write(document, out) out end
Creates a custom metadata subject for HTTP requests.
# File lib/nexus_cli/n3_metadata.rb, line 24 def create_base64_subject(artifact) return Base64.urlsafe_encode64("urn:maven/artifact##{artifact.group_id}:#{artifact.artifact_id}:#{artifact.version}::#{artifact.extension}") end
Create the request from the specified list of custom metadata key:value pairs @info If the target hash contains empty values for a key that exist in source, the metadata will be deleted @param [Hash] source The source hash of custom metadata key:value pairs @param [Hash] target The target hash to merge with the source hash (optional) @result [Hash] The resulting merge of the source and target hashes
# File lib/nexus_cli/n3_metadata.rb, line 58 def create_metadata_hash(source, target={}) request = [] source.merge(target).each do |key, value| request.push({:namespace => "urn:nexus/user#", :key => key, :value => value, :readOnly => false}) unless value.empty? end return request end
# File lib/nexus_cli/n3_metadata.rb, line 66 def missing_custom_metadata?(custom_metadata) return !custom_metadata.match(/<data[ ]*\/>/).nil? ? true : false end
Checks if the custom metadata key is valid. Valid characters are alphanumeric with no special characeters.
# File lib/nexus_cli/n3_metadata.rb, line 8 def valid_n3_key?(element) return !element.nil? && !element.match(/^[a-zA-Z0-9]+$/).nil? ? true : false end
Check if the custom metadata search type is valid.
# File lib/nexus_cli/n3_metadata.rb, line 19 def valid_n3_search_type?(element) return !element.nil? && ["equal", "notequal", "matches", "bounded"].include?(element) end
Checks if the custom metadata value is valid. Valid characters are anything but quotes.
# File lib/nexus_cli/n3_metadata.rb, line 14 def valid_n3_value?(element) return !element.nil? && !element.match(/^[^"'\\]*$/).nil? ? true : false end
Private Class Methods
# File lib/nexus_cli/n3_metadata.rb, line 72 def create_tag(tag, value) "<#{tag}>#{value}</#{tag}>" end