Module: Sbmt::Outbox

Defined in:
lib/sbmt/outbox.rb,
lib/sbmt/outbox/cli.rb,
lib/sbmt/outbox/engine.rb,
lib/sbmt/outbox/errors.rb,
lib/sbmt/outbox/logger.rb,
lib/sbmt/outbox/version.rb,
lib/sbmt/outbox/ascii_art.rb,
lib/sbmt/outbox/v1/worker.rb,
lib/sbmt/outbox/v2/poller.rb,
lib/sbmt/outbox/v2/worker.rb,
lib/sbmt/outbox/probes/probe.rb,
lib/sbmt/outbox/v1/throttler.rb,
lib/sbmt/outbox/v2/processor.rb,
lib/sbmt/outbox/v2/redis_job.rb,
lib/sbmt/outbox/v2/throttler.rb,
lib/sbmt/outbox/error_tracker.rb,
lib/sbmt/outbox/metrics/utils.rb,
lib/sbmt/outbox/v2/tasks/base.rb,
lib/sbmt/outbox/v2/tasks/poll.rb,
lib/sbmt/outbox/probes/metrics.rb,
lib/sbmt/outbox/v1/thread_pool.rb,
lib/sbmt/outbox/v2/thread_pool.rb,
app/models/sbmt/outbox/base_item.rb,
lib/sbmt/outbox/v2/box_processor.rb,
lib/sbmt/outbox/v2/tasks/default.rb,
lib/sbmt/outbox/v2/tasks/process.rb,
app/models/sbmt/outbox/inbox_item.rb,
lib/sbmt/outbox/database_switcher.rb,
lib/sbmt/outbox/middleware/runner.rb,
lib/sbmt/outbox/v2/poll_throttler.rb,
app/models/sbmt/outbox/outbox_item.rb,
lib/sbmt/outbox/middleware/builder.rb,
app/models/sbmt/outbox/api/box_class.rb,
lib/sbmt/outbox/redis_client_factory.rb,
app/models/sbmt/outbox/api/inbox_class.rb,
lib/sbmt/outbox/v2/poll_throttler/base.rb,
lib/sbmt/outbox/v2/poll_throttler/noop.rb,
app/models/sbmt/outbox/api/outbox_class.rb,
app/models/sbmt/outbox/base_item_config.rb,
app/interactors/sbmt/outbox/process_item.rb,
app/models/sbmt/outbox/inbox_item_config.rb,
app/models/sbmt/outbox/outbox_item_config.rb,
app/interactors/sbmt/outbox/dry_interactor.rb,
app/controllers/sbmt/outbox/root_controller.rb,
lib/sbmt/outbox/v2/poll_throttler/composite.rb,
app/interactors/sbmt/outbox/base_create_item.rb,
lib/sbmt/outbox/v2/poll_throttler/paused_box.rb,
app/interactors/sbmt/outbox/create_inbox_item.rb,
app/models/sbmt/outbox/api/application_record.rb,
lib/sbmt/outbox/middleware/sentry/transaction.rb,
lib/sbmt/outbox/v2/poll_throttler/fixed_delay.rb,
app/interactors/sbmt/outbox/create_outbox_item.rb,
lib/sbmt/outbox/v2/poll_throttler/rate_limited.rb,
app/controllers/sbmt/outbox/api/base_controller.rb,
app/interactors/sbmt/outbox/create_outbox_batch.rb,
app/jobs/sbmt/outbox/base_delete_stale_items_job.rb,
app/interactors/sbmt/outbox/retry_strategies/base.rb,
app/jobs/sbmt/outbox/delete_stale_inbox_items_job.rb,
app/jobs/sbmt/outbox/delete_stale_outbox_items_job.rb,
lib/sbmt/outbox/v2/poll_throttler/redis_queue_size.rb,
app/interactors/sbmt/outbox/retry_strategies/no_delay.rb,
lib/sbmt/outbox/instrumentation/open_telemetry_loader.rb,
lib/sbmt/outbox/v2/poll_throttler/redis_queue_time_lag.rb,
app/controllers/sbmt/outbox/api/inbox_classes_controller.rb,
app/controllers/sbmt/outbox/api/outbox_classes_controller.rb,
app/interactors/sbmt/outbox/retry_strategies/compacted_log.rb,
app/interactors/sbmt/outbox/retry_strategies/latest_available.rb,
app/interactors/sbmt/outbox/retry_strategies/exponential_backoff.rb,
lib/sbmt/outbox/middleware/sentry/tracing_item_process_middleware.rb,
app/interactors/sbmt/outbox/partition_strategies/hash_partitioning.rb,
lib/sbmt/outbox/middleware/sentry/tracing_batch_process_middleware.rb,
app/interactors/sbmt/outbox/partition_strategies/number_partitioning.rb,
lib/sbmt/outbox/middleware/open_telemetry/tracing_create_item_middleware.rb,
lib/sbmt/outbox/middleware/open_telemetry/tracing_create_batch_middleware.rb,
lib/sbmt/outbox/middleware/open_telemetry/tracing_item_process_middleware.rb,
lib/sbmt/outbox/middleware/execution_context/context_item_process_middleware.rb

Defined Under Namespace

Modules: Api, AsciiArt, Instrumentation, Metrics, Middleware, PartitionStrategies, Probes, RedisClientFactory, RetryStrategies, V1, V2 Classes: BaseCreateItem, BaseDeleteStaleItemsJob, BaseItem, BaseItemConfig, CLI, ConfigError, CreateInboxItem, CreateOutboxBatch, CreateOutboxItem, DatabaseError, DatabaseSwitcher, DeleteStaleInboxItemsJob, DeleteStaleOutboxItemsJob, DryInteractor, Engine, Error, ErrorTracker, InboxItem, InboxItemConfig, Logger, OutboxItem, OutboxItemConfig, ProcessItem, RootController

Constant Summary collapse

VERSION =
"6.9.0"

Class Attribute Summary collapse

Class Method Summary collapse

Class Attribute Details

.current_workerObject

Returns the value of attribute current_worker.



47
48
49
# File 'lib/sbmt/outbox.rb', line 47

def current_worker
  @current_worker
end

Class Method Details

.action_controller_api_base_classObject



80
81
82
# File 'lib/sbmt/outbox.rb', line 80

def action_controller_api_base_class
  @action_controller_api_base_class ||= config.action_controller_api_base_class.safe_constantize || ::ActionController::API
end

.action_controller_base_classObject



84
85
86
# File 'lib/sbmt/outbox.rb', line 84

def action_controller_base_class
  @action_controller_base_class ||= config.action_controller_base_class.safe_constantize || ::ActionController::Base
end

.active_job_base_classObject



76
77
78
# File 'lib/sbmt/outbox.rb', line 76

def active_job_base_class
  @active_job_base_class ||= config.active_job_base_class.safe_constantize || ::ActiveJob::Base
end

.active_record_base_classObject



72
73
74
# File 'lib/sbmt/outbox.rb', line 72

def active_record_base_class
  @active_record_base_class ||= config.active_record_base_class.safe_constantize || ::ActiveRecord::Base
end

.batch_process_middlewaresObject



158
159
160
# File 'lib/sbmt/outbox.rb', line 158

def batch_process_middlewares
  @batch_process_middlewares ||= config.batch_process_middlewares.map(&:constantize)
end

.configObject



52
53
54
# File 'lib/sbmt/outbox.rb', line 52

def config
  @config ||= Rails.application.config.outbox
end

.create_batch_middlewaresObject



170
171
172
# File 'lib/sbmt/outbox.rb', line 170

def create_batch_middlewares
  @create_batch_middlewares ||= config.create_batch_middlewares.map(&:constantize)
end

.create_item_middlewaresObject



166
167
168
# File 'lib/sbmt/outbox.rb', line 166

def create_item_middlewares
  @create_item_middlewares ||= config.create_item_middlewares.map(&:constantize)
end

.database_switcherObject



92
93
94
# File 'lib/sbmt/outbox.rb', line 92

def database_switcher
  @database_switcher ||= config.database_switcher.constantize
end

.default_worker_versionObject



68
69
70
# File 'lib/sbmt/outbox.rb', line 68

def default_worker_version
  @default_worker_version ||= config.default_worker_version&.to_i || 2
end

.error_trackerObject



88
89
90
# File 'lib/sbmt/outbox.rb', line 88

def error_tracker
  @error_tracker ||= config.error_tracker.constantize
end

.inbox_item_classesObject



114
115
116
117
118
119
120
# File 'lib/sbmt/outbox.rb', line 114

def inbox_item_classes
  @inbox_item_classes ||= if config.inbox_item_classes.empty?
    (yaml_config[:inbox_items] || {}).keys.map { |name| name.camelize.constantize }
  else
    config.inbox_item_classes.map(&:constantize)
  end
end

.item_classesObject



122
123
124
# File 'lib/sbmt/outbox.rb', line 122

def item_classes
  @item_classes ||= outbox_item_classes + inbox_item_classes
end

.item_classes_by_nameObject



126
127
128
# File 'lib/sbmt/outbox.rb', line 126

def item_classes_by_name
  @item_classes_by_name ||= item_classes.index_by(&:box_name)
end

.item_process_middlewaresObject



162
163
164
# File 'lib/sbmt/outbox.rb', line 162

def item_process_middlewares
  @item_process_middlewares ||= config.item_process_middlewares.map(&:constantize)
end

.load_yaml(path) ⇒ Object



146
147
148
149
150
151
152
153
154
155
156
# File 'lib/sbmt/outbox.rb', line 146

def load_yaml(path)
  data = if Gem::Version.new(Psych::VERSION) >= Gem::Version.new("4.0.0")
    YAML.safe_load(ERB.new(File.read(path)).result, aliases: true)
  else
    YAML.safe_load(ERB.new(File.read(path)).result, [], [], true)
  end

  data
    .with_indifferent_access
    .fetch(Rails.env, {})
end

.loggerObject



56
57
58
# File 'lib/sbmt/outbox.rb', line 56

def logger
  @logger ||= Sbmt::Outbox::Logger.new
end

.memory_storeObject



102
103
104
# File 'lib/sbmt/outbox.rb', line 102

def memory_store
  @memory_store ||= ActiveSupport::Cache::MemoryStore.new
end

.outbox_item_classesObject



106
107
108
109
110
111
112
# File 'lib/sbmt/outbox.rb', line 106

def outbox_item_classes
  @outbox_item_classes ||= if config.outbox_item_classes.empty?
    (yaml_config[:outbox_items] || {}).keys.map { |name| name.camelize.constantize }
  else
    config.outbox_item_classes.map(&:constantize)
  end
end

.poller_configObject



60
61
62
# File 'lib/sbmt/outbox.rb', line 60

def poller_config
  @poller_config ||= config.poller
end

.processor_configObject



64
65
66
# File 'lib/sbmt/outbox.rb', line 64

def processor_config
  @processor_config ||= config.processor
end

.redisObject



96
97
98
99
100
# File 'lib/sbmt/outbox.rb', line 96

def redis
  @redis ||= ConnectionPool::Wrapper.new(size: ENV.fetch("RAILS_MAX_THREADS", 5).to_i) do
    RedisClientFactory.build(config.redis)
  end
end

.yaml_configObject



130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
# File 'lib/sbmt/outbox.rb', line 130

def yaml_config
  return @yaml_config if defined?(@yaml_config)

  paths = if config.paths.empty?
    [Rails.root.join("config/outbox.yml").to_s]
  else
    config.paths
  end

  @yaml_config = paths.each_with_object({}.with_indifferent_access) do |path, memo|
    memo.deep_merge!(
      load_yaml(path)
    )
  end
end