Module: McAPI::Utils

Defined in:
lib/mcapi/encryption/utils/utils.rb

Overview

Utils module

Class Method Summary collapse

Class Method Details

.contains(config, props) ⇒ Object



57
58
59
60
61
# File 'lib/mcapi/encryption/utils/utils.rb', line 57

def self.contains(config, props)
  props.any? do |i|
    config.key? i
  end
end

.create_message_digest(digest) ⇒ Object

Create Digest object for the provided digest string



44
45
46
47
48
49
50
51
52
53
54
55
# File 'lib/mcapi/encryption/utils/utils.rb', line 44

def self.create_message_digest(digest)
  return unless digest

  case digest.upcase
  when 'SHA-256', 'SHA256'
    OpenSSL::Digest::SHA256
  when 'SHA-512', 'SHA512'
    OpenSSL::Digest::SHA512
  else
    raise 'Digest algorithm not supported'
  end
end

.decode(data, encoding) ⇒ Object

Data decoding



28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/mcapi/encryption/utils/utils.rb', line 28

def self.decode(data, encoding)
  return unless encoding

  case encoding.downcase
  when 'hex'
    [data].pack('H*')
  when 'base64'
    Base64.decode64(data)
  else
    raise 'Encoding not supported'
  end
end

.delete_node(path, obj, properties = []) ⇒ Object

Delete node from JSON object



96
97
98
99
100
101
102
103
104
105
106
107
108
109
# File 'lib/mcapi/encryption/utils/utils.rb', line 96

def self.delete_node(path, obj, properties = [])
  return unless path && obj

  paths = path.split('.')
  to_delete = paths[paths.size - 1]
  paths.each_with_index do |e, index|
    prev = obj
    next unless obj[e]

    obj = obj[e]
    prev.delete(to_delete) if obj && index == paths.size - 1
  end
  properties.each { |e| obj.delete(e) } if paths.empty?
end

.encode(data, encoding) ⇒ Object

Data encoding



12
13
14
15
16
17
18
19
20
21
22
23
# File 'lib/mcapi/encryption/utils/utils.rb', line 12

def self.encode(data, encoding)
  return unless encoding

  case encoding.downcase
  when 'hex'
    data.each_byte.map { |b| format('%02x', b.to_i) }.join
  when 'base64'
    Base64.encode64(data).delete("\n")
  else
    raise 'Encoding not supported'
  end
end

.mutate_obj_prop(path, value, obj, src_path = nil, properties = []) ⇒ Object

Perform JSON object properties manipulations



66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# File 'lib/mcapi/encryption/utils/utils.rb', line 66

def self.mutate_obj_prop(path, value, obj, src_path = nil, properties = [])
  tmp = obj
  prev = nil
  return unless path

  delete_node(src_path, obj, properties) if src_path
  paths = path.split('.')
  paths.each do |e|
    tmp[e] = {} unless tmp[e]
    prev = tmp
    tmp = tmp[e]
  end
  elem = path.split('.').pop
  if value.is_a?(Hash) && !value.is_a?(Array)
    prev[elem] = {} unless prev[elem].is_a?(Hash)
    override_props(prev[elem], value)
  else
    prev[elem] = value
  end
end

.override_props(target, obj) ⇒ Object



87
88
89
90
91
# File 'lib/mcapi/encryption/utils/utils.rb', line 87

def self.override_props(target, obj)
  obj.each do |k, _|
    target[k] = obj[k]
  end
end

.parse_header(raw) ⇒ Object

Parse raw HTTP Header



114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
# File 'lib/mcapi/encryption/utils/utils.rb', line 114

def self.parse_header(raw)
  raw = raw.partition("\n").last
  header = Hash.new([].freeze)
  field = nil
  raw.each_line do |line|
    case line
    when /^([A-Za-z0-9!\#$%&'*+\-.^_`|~]+):\s*(.*?)\s*\z/om
      field = Regexp.last_match(1)
      value = Regexp.last_match(2)
      field.downcase!
      header[field] = [] unless header.key?(field)
      header[field] << value
    when /^\s+(.*?)\s*\z/om
      value = Regexp.last_match(1)
      raise Exception, "bad header '#{line}'." unless field

      header[field][-1] << ' ' << value
    else
      raise Exception, "bad header '#{line}'."
    end
  end
  header.each do |_key, values|
    values.each do |value|
      value.strip!
      value.gsub!(/\s+/, ' ')
    end
  end
  header
end