Class: AvroPinions::Message

Inherits:
Object
  • Object
show all
Defined in:
lib/avro_pinions/message.rb

Defined Under Namespace

Classes: InvalidRecord

Instance Method Summary collapse

Instance Method Details

#avro_schemaObject



50
51
52
# File 'lib/avro_pinions/message.rb', line 50

def avro_schema
  @avro_schema ||= AvroPinions.schema_registry.schema(schema, namespace)
end

#codecObject



46
47
48
# File 'lib/avro_pinions/message.rb', line 46

def codec
  @codec ||= AvroPinions::Codec.new(avro_schema)
end

#encodeObject



38
39
40
# File 'lib/avro_pinions/message.rb', line 38

def encode
  codec.encode(record)
end

#namespaceObject



22
23
24
25
26
27
28
# File 'lib/avro_pinions/message.rb', line 22

def namespace
  if defined?(self.class::NAMESPACE)
    self.class::NAMESPACE
  else
    raise AvroPinions::NotFullyImplementedError, 'No Namespace defined'
  end
end

#publishObject



34
35
36
# File 'lib/avro_pinions/message.rb', line 34

def publish
  AvroPinions.publisher.publish(topic, record)
end

#recordObject



30
31
32
# File 'lib/avro_pinions/message.rb', line 30

def record
  raise AvroPinions::NotFullyImplementedError, 'record method not implemented'
end

#schemaObject

Schema is inferred to be the .avsc file in the schemas folder with the name as given



14
15
16
17
18
19
20
# File 'lib/avro_pinions/message.rb', line 14

def schema
  if defined?(self.class::SCHEMA)
    self.class::SCHEMA
  else
    raise AvroPinions::NotFullyImplementedError, 'No Schema defined'
  end
end

#topicObject



3
4
5
6
7
8
9
10
# File 'lib/avro_pinions/message.rb', line 3

def topic
  # self.class::SYMBOL looks up a class constant in a child class
  if defined?(self.class::TOPIC)
    self.class::TOPIC
  else
    raise AvroPinions::NotFullyImplementedError, 'No Topic defined'
  end
end

#valid?Boolean

Returns:

  • (Boolean)


42
43
44
# File 'lib/avro_pinions/message.rb', line 42

def valid?
  Avro::Schema.validate(avro_schema, AvroPinions::Codec.pedantic_data(record))
end