Sha256: f40740cd30fcd6d22097a78664e88025421b0c4190e42e1407bcd7a5125feec4

Contents?: true

Size: 1.81 KB

Versions: 20

Compression:

Stored size: 1.81 KB

Contents

#!/usr/bin/env ruby

require_relative '../config/environment'

# Setup classes which are Apache Avro schema compatible, can be anything which
# be converted to a hash via +#to_h+ (eg. OpenStruct, RecursiveOpenStruct,
# Class, Struct, etc)
PaymentEvent = Struct.new(:event, :payment,
                          keyword_init: true)

Payment = Struct.new(:gid, :currency, :net_amount_sum, :items, :state,
                     :created_at, :updated_at,
                     keyword_init: true)

PaymentItem = Struct.new(:gid, :net_amount, :tax_rate, :created_at, :updated_at,
                         keyword_init: true)

# Setup the real data instances which we serialize with Apache Avro and push to
# Apache Kafka
item_1_id = SecureRandom.uuid
item_1 = PaymentItem.new(gid: "gid://playground-app/PaymentItem/#{item_1_id}",
                         net_amount: 499,
                         tax_rate: 19,
                         created_at: Time.current,
                         updated_at: nil)

item_2_id = SecureRandom.uuid
item_2 = PaymentItem.new(gid: "gid://playground-app/PaymentItem/#{item_2_id}",
                         net_amount: 1,
                         tax_rate: 19,
                         created_at: Time.current,
                         updated_at: nil)

payment_id = SecureRandom.uuid
payment = Payment.new(gid: "gid://playground-app/Payment/#{payment_id}",
                      currency: :eur,
                      net_amount_sum: 500,
                      state: :authorized,
                      items: [item_1, item_2],
                      created_at: Time.current,
                      updated_at: Time.current)

event = PaymentEvent.new(event: :payment_authorized, payment: payment)
event_hash = Rimless.avro_sanitize(event)

pp event_hash

Rimless.message(data: event_hash, topic: :payments, schema: :payment_v1_event)

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
rimless-1.10.2 doc/kafka-playground/examples/rimless-produce
rimless-1.10.1 doc/kafka-playground/examples/rimless-produce
rimless-1.10.0 doc/kafka-playground/examples/rimless-produce
rimless-1.9.0 doc/kafka-playground/examples/rimless-produce
rimless-1.8.0 doc/kafka-playground/examples/rimless-produce
rimless-1.7.7 doc/kafka-playground/examples/rimless-produce
rimless-1.7.6 doc/kafka-playground/examples/rimless-produce
rimless-1.7.5 doc/kafka-playground/examples/rimless-produce
rimless-1.7.4 doc/kafka-playground/examples/rimless-produce
rimless-1.7.3 doc/kafka-playground/examples/rimless-produce
rimless-1.7.2 doc/kafka-playground/examples/rimless-produce
rimless-1.7.1 doc/kafka-playground/examples/rimless-produce
rimless-1.7.0 doc/kafka-playground/examples/rimless-produce
rimless-1.6.0 doc/kafka-playground/examples/rimless-produce
rimless-1.5.1 doc/kafka-playground/examples/rimless-produce
rimless-1.5.0 doc/kafka-playground/examples/rimless-produce
rimless-1.4.2 doc/kafka-playground/examples/rimless-produce
rimless-1.4.1 doc/kafka-playground/examples/rimless-produce
rimless-1.4.0 doc/kafka-playground/examples/rimless-produce
rimless-1.3.0 doc/kafka-playground/examples/rimless-produce