karafka-web 0.10.4 → 0.11.0.beta1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/CHANGELOG.md +54 -176
- data/Gemfile +4 -0
- data/Gemfile.lock +87 -43
- data/LICENSE +6 -2
- data/bin/verify_kafka_warnings +35 -0
- data/bin/verify_topics_naming +35 -0
- data/config/locales/pro_errors.yml +1 -0
- data/docker-compose.yml +1 -1
- data/gulpfile.js +0 -2
- data/karafka-web.gemspec +2 -2
- data/lib/karafka/web/config.rb +80 -9
- data/lib/karafka/web/contracts/config.rb +44 -5
- data/lib/karafka/web/errors.rb +10 -0
- data/lib/karafka/web/management/actions/create_initial_states.rb +6 -6
- data/lib/karafka/web/management/actions/create_topics.rb +30 -64
- data/lib/karafka/web/management/actions/delete_topics.rb +5 -5
- data/lib/karafka/web/management/actions/enable.rb +5 -5
- data/lib/karafka/web/pro/commanding/commands/base.rb +37 -13
- data/lib/karafka/web/pro/commanding/commands/consumers/quiet.rb +33 -0
- data/lib/karafka/web/pro/commanding/commands/consumers/stop.rb +32 -0
- data/lib/karafka/web/pro/commanding/commands/consumers/trace.rb +37 -0
- data/lib/karafka/web/pro/commanding/commands/partitions/pause.rb +30 -0
- data/lib/karafka/web/pro/commanding/commands/partitions/resume.rb +30 -0
- data/lib/karafka/web/pro/commanding/commands/partitions/seek.rb +30 -0
- data/lib/karafka/web/pro/commanding/config.rb +6 -10
- data/lib/karafka/web/pro/commanding/contracts/config.rb +2 -10
- data/lib/karafka/web/pro/commanding/dispatcher.rb +45 -24
- data/lib/karafka/web/pro/commanding/handlers/partitions/commands/base.rb +67 -0
- data/lib/karafka/web/pro/commanding/handlers/partitions/commands/pause.rb +44 -0
- data/lib/karafka/web/pro/commanding/handlers/partitions/commands/resume.rb +29 -0
- data/lib/karafka/web/pro/commanding/handlers/partitions/commands/seek.rb +86 -0
- data/lib/karafka/web/pro/commanding/handlers/partitions/executor.rb +56 -0
- data/lib/karafka/web/pro/commanding/handlers/partitions/listener.rb +55 -0
- data/lib/karafka/web/pro/commanding/handlers/partitions/tracker.rb +62 -0
- data/lib/karafka/web/pro/commanding/listener.rb +4 -12
- data/lib/karafka/web/pro/commanding/manager.rb +36 -24
- data/lib/karafka/web/pro/commanding/matcher.rb +7 -17
- data/lib/karafka/web/pro/commanding/request.rb +39 -0
- data/lib/karafka/web/pro/commanding.rb +2 -10
- data/lib/karafka/web/pro/loader.rb +13 -10
- data/lib/karafka/web/pro/ui/app.rb +31 -390
- data/lib/karafka/web/pro/ui/controllers/base_controller.rb +8 -10
- data/lib/karafka/web/pro/ui/controllers/cluster_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/consumers/base_controller.rb +21 -0
- data/lib/karafka/web/pro/ui/controllers/consumers/commanding_controller.rb +148 -0
- data/lib/karafka/web/pro/ui/controllers/consumers/commands_controller.rb +96 -0
- data/lib/karafka/web/pro/ui/controllers/consumers/consumers_controller.rb +101 -0
- data/lib/karafka/web/pro/ui/controllers/consumers/controls_controller.rb +36 -0
- data/lib/karafka/web/pro/ui/controllers/consumers/jobs_controller.rb +57 -0
- data/lib/karafka/web/pro/ui/controllers/consumers/partitions/base_controller.rb +86 -0
- data/lib/karafka/web/pro/ui/controllers/consumers/partitions/offsets_controller.rb +75 -0
- data/lib/karafka/web/pro/ui/controllers/consumers/partitions/pauses_controller.rb +110 -0
- data/lib/karafka/web/pro/ui/controllers/dashboard_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/dlq_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/errors_controller.rb +3 -11
- data/lib/karafka/web/pro/ui/controllers/explorer/base_controller.rb +21 -0
- data/lib/karafka/web/pro/ui/controllers/explorer/explorer_controller.rb +215 -0
- data/lib/karafka/web/pro/ui/controllers/explorer/messages_controller.rb +145 -0
- data/lib/karafka/web/pro/ui/controllers/explorer/search_controller.rb +68 -0
- data/lib/karafka/web/pro/ui/controllers/health_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/jobs_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/recurring_tasks_controller.rb +12 -13
- data/lib/karafka/web/pro/ui/controllers/routing_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/scheduled_messages/base_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/scheduled_messages/explorer_controller.rb +8 -16
- data/lib/karafka/web/pro/ui/controllers/scheduled_messages/messages_controller.rb +9 -15
- data/lib/karafka/web/pro/ui/controllers/scheduled_messages/schedules_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/status_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/support_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/controllers/topics/base_controller.rb +21 -0
- data/lib/karafka/web/pro/ui/controllers/topics/configs_controller.rb +86 -0
- data/lib/karafka/web/pro/ui/controllers/topics/distributions_controller.rb +91 -0
- data/lib/karafka/web/pro/ui/controllers/topics/offsets_controller.rb +55 -0
- data/lib/karafka/web/pro/ui/controllers/topics/replications_controller.rb +37 -0
- data/lib/karafka/web/pro/ui/controllers/topics/topics_controller.rb +101 -0
- data/lib/karafka/web/pro/ui/controllers/ux_controller.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/branding/config.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/branding/contracts/config.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/branding.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/features.rb +53 -0
- data/lib/karafka/web/pro/ui/lib/patterns_detector.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/policies/config.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/policies/contracts/config.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/policies/messages.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/policies/requests.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/policies.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/safe_runner.rb +5 -0
- data/lib/karafka/web/pro/ui/lib/search/config.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/search/contracts/config.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/search/contracts/form.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/search/matchers/base.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/search/matchers/raw_header_includes.rb +10 -11
- data/lib/karafka/web/pro/ui/lib/search/matchers/raw_key_includes.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/search/matchers/raw_payload_includes.rb +23 -11
- data/lib/karafka/web/pro/ui/lib/search/normalizer.rb +2 -10
- data/lib/karafka/web/pro/ui/lib/search/runner.rb +3 -11
- data/lib/karafka/web/pro/ui/lib/search.rb +2 -10
- data/lib/karafka/web/pro/ui/routes/base.rb +19 -0
- data/lib/karafka/web/pro/ui/routes/cluster.rb +37 -0
- data/lib/karafka/web/pro/ui/routes/consumers.rb +145 -0
- data/lib/karafka/web/pro/ui/routes/dashboard.rb +25 -0
- data/lib/karafka/web/pro/ui/routes/dlq.rb +24 -0
- data/lib/karafka/web/pro/ui/routes/errors.rb +39 -0
- data/lib/karafka/web/pro/ui/routes/explorer.rb +118 -0
- data/lib/karafka/web/pro/ui/routes/health.rb +47 -0
- data/lib/karafka/web/pro/ui/routes/jobs.rb +33 -0
- data/lib/karafka/web/pro/ui/routes/recurring_tasks.rb +59 -0
- data/lib/karafka/web/pro/ui/routes/routing.rb +31 -0
- data/lib/karafka/web/pro/ui/routes/scheduled_messages.rb +75 -0
- data/lib/karafka/web/pro/ui/routes/status.rb +24 -0
- data/lib/karafka/web/pro/ui/routes/support.rb +24 -0
- data/lib/karafka/web/pro/ui/routes/topics.rb +90 -0
- data/lib/karafka/web/pro/ui/routes/ux.rb +24 -0
- data/lib/karafka/web/pro/ui/views/cluster/_breadcrumbs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/cluster/_broker.erb +3 -0
- data/lib/karafka/web/pro/ui/views/cluster/_config.erb +3 -0
- data/lib/karafka/web/pro/ui/views/cluster/_tabs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/cluster/index.erb +4 -1
- data/lib/karafka/web/pro/ui/views/cluster/show.erb +3 -0
- data/lib/karafka/web/pro/ui/views/{commands → consumers/commands}/_backtrace.erb +3 -0
- data/lib/karafka/web/pro/ui/views/consumers/commands/_breadcrumbs.erb +24 -0
- data/lib/karafka/web/pro/ui/views/{commands → consumers/commands}/_command.erb +22 -6
- data/lib/karafka/web/pro/ui/views/consumers/commands/_command_details.erb +4 -0
- data/lib/karafka/web/pro/ui/views/consumers/commands/_empty.erb +6 -0
- data/lib/karafka/web/pro/ui/views/{commands → consumers/commands}/_incompatible_schema.erb +3 -0
- data/lib/karafka/web/pro/ui/views/{commands → consumers/commands}/_metadata.erb +4 -1
- data/lib/karafka/web/pro/ui/views/{commands → consumers/commands}/_table.erb +5 -2
- data/lib/karafka/web/pro/ui/views/{commands → consumers/commands}/index.erb +7 -4
- data/lib/karafka/web/pro/ui/views/consumers/commands/show.erb +32 -0
- data/lib/karafka/web/pro/ui/views/consumers/consumers/_breadcrumbs.erb +46 -0
- data/lib/karafka/web/pro/ui/views/consumers/consumers/_consumer.erb +59 -0
- data/lib/karafka/web/pro/ui/views/consumers/consumers/_consumer_performance.erb +71 -0
- data/lib/karafka/web/pro/ui/views/consumers/consumers/_tabs.erb +38 -0
- data/lib/karafka/web/pro/ui/views/consumers/consumers/consumer/_commands.erb +80 -0
- data/lib/karafka/web/pro/ui/views/consumers/consumers/consumer/_consumer_group.erb +11 -0
- data/lib/karafka/web/pro/ui/views/consumers/{consumer → consumers/consumer}/_metrics.erb +3 -0
- data/lib/karafka/web/pro/ui/views/consumers/consumers/consumer/_no_subscriptions.erb +10 -0
- data/lib/karafka/web/pro/ui/views/consumers/{consumer → consumers/consumer}/_partition.erb +16 -0
- data/lib/karafka/web/pro/ui/views/consumers/consumers/consumer/_partition_edit_options.erb +33 -0
- data/lib/karafka/web/pro/ui/views/consumers/{consumer → consumers/consumer}/_stopped.erb +3 -0
- data/lib/karafka/web/pro/ui/views/consumers/{consumer → consumers/consumer}/_subscription_group.erb +7 -3
- data/lib/karafka/web/pro/ui/views/consumers/{consumer → consumers/consumer}/_tabs.erb +7 -4
- data/lib/karafka/web/pro/ui/views/consumers/consumers/details.erb +15 -0
- data/lib/karafka/web/pro/ui/views/consumers/{index.erb → consumers/index.erb} +6 -3
- data/lib/karafka/web/pro/ui/views/consumers/{performance.erb → consumers/performance.erb} +6 -3
- data/lib/karafka/web/pro/ui/views/consumers/consumers/subscriptions.erb +24 -0
- data/lib/karafka/web/pro/ui/views/consumers/controls/_breadcrumbs.erb +16 -0
- data/lib/karafka/web/pro/ui/views/consumers/controls/_controls.erb +107 -0
- data/lib/karafka/web/pro/ui/views/consumers/{controls.erb → controls/index.erb} +8 -5
- data/lib/karafka/web/pro/ui/views/consumers/jobs/_breadcrumbs.erb +36 -0
- data/lib/karafka/web/pro/ui/views/consumers/{consumer → jobs}/_job.erb +3 -0
- data/lib/karafka/web/pro/ui/views/consumers/{consumer → jobs}/_no_jobs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/consumers/{pending_jobs.erb → jobs/pending.erb} +7 -8
- data/lib/karafka/web/pro/ui/views/consumers/{running_jobs.erb → jobs/running.erb} +7 -8
- data/lib/karafka/web/pro/ui/views/consumers/partitions/offsets/_basics.erb +77 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/offsets/_breadcrumbs.erb +58 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/offsets/_form.erb +109 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/offsets/_not_running_error.erb +16 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/offsets/_running_warning.erb +15 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/offsets/edit.erb +12 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/_active_not_editable.erb +22 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/_adjusting_warning.erb +27 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/_breadcrumbs.erb +60 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/_edit_form.erb +59 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/_lrj_not_manageable.erb +24 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/_new_form.erb +78 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/_not_running.erb +16 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/edit.erb +20 -0
- data/lib/karafka/web/pro/ui/views/consumers/partitions/pauses/new.erb +16 -0
- data/lib/karafka/web/pro/ui/views/dashboard/index.erb +4 -1
- data/lib/karafka/web/pro/ui/views/dlq/_breadcrumbs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/dlq/_no_topics.erb +3 -0
- data/lib/karafka/web/pro/ui/views/dlq/_topic.erb +4 -1
- data/lib/karafka/web/pro/ui/views/dlq/index.erb +3 -0
- data/lib/karafka/web/pro/ui/views/errors/_breadcrumbs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/errors/_error.erb +3 -0
- data/lib/karafka/web/pro/ui/views/errors/_partition_option.erb +3 -0
- data/lib/karafka/web/pro/ui/views/errors/_selector.erb +3 -0
- data/lib/karafka/web/pro/ui/views/errors/_table.erb +4 -1
- data/lib/karafka/web/pro/ui/views/errors/index.erb +6 -3
- data/lib/karafka/web/pro/ui/views/errors/partition.erb +5 -2
- data/lib/karafka/web/pro/ui/views/errors/show.erb +3 -0
- data/lib/karafka/web/pro/ui/views/explorer/{_breadcrumbs.erb → explorer/_breadcrumbs.erb} +7 -4
- data/lib/karafka/web/pro/ui/views/explorer/{_failed_deserialization.erb → explorer/_failed_deserialization.erb} +3 -0
- data/lib/karafka/web/pro/ui/views/explorer/{_filtered.erb → explorer/_filtered.erb} +3 -0
- data/lib/karafka/web/pro/ui/views/explorer/{_message.erb → explorer/_message.erb} +4 -1
- data/lib/karafka/web/pro/ui/views/explorer/explorer/_no_topics.erb +4 -0
- data/lib/karafka/web/pro/ui/views/explorer/{_partition_option.erb → explorer/_partition_option.erb} +4 -1
- data/lib/karafka/web/pro/ui/views/explorer/{_selector.erb → explorer/_selector.erb} +4 -1
- data/lib/karafka/web/pro/ui/views/explorer/explorer/_topic.erb +13 -0
- data/lib/karafka/web/pro/ui/views/explorer/explorer/index.erb +17 -0
- data/lib/karafka/web/pro/ui/views/explorer/{message → explorer/message}/_metadata.erb +10 -7
- data/lib/karafka/web/pro/ui/views/explorer/{message → explorer/message}/_payload.erb +6 -3
- data/lib/karafka/web/pro/ui/views/explorer/{message → explorer/message}/_resources_utilization.erb +7 -4
- data/lib/karafka/web/pro/ui/views/explorer/{message → explorer/message}/_too_big_to_be_displayed.erb +3 -0
- data/lib/karafka/web/pro/ui/views/explorer/{messages → explorer/messages}/_detail.erb +3 -0
- data/lib/karafka/web/pro/ui/views/explorer/explorer/messages/_headers.erb +51 -0
- data/lib/karafka/web/pro/ui/views/explorer/{messages → explorer/messages}/_key.erb +3 -0
- data/lib/karafka/web/pro/ui/views/explorer/explorer/partition/_cleaned.erb +6 -0
- data/lib/karafka/web/pro/ui/views/explorer/explorer/partition/_empty.erb +6 -0
- data/lib/karafka/web/pro/ui/views/explorer/{partition → explorer/partition}/_messages.erb +4 -1
- data/lib/karafka/web/pro/ui/views/explorer/explorer/partition/_time_selector.erb +16 -0
- data/lib/karafka/web/pro/ui/views/explorer/explorer/partition/_timestamp_selector.erb +33 -0
- data/lib/karafka/web/pro/ui/views/explorer/{partition.erb → explorer/partition.erb} +24 -17
- data/lib/karafka/web/pro/ui/views/explorer/{show.erb → explorer/show.erb} +17 -19
- data/lib/karafka/web/pro/ui/views/explorer/{topic → explorer/topic}/_actions.erb +5 -2
- data/lib/karafka/web/pro/ui/views/explorer/explorer/topic/_empty.erb +6 -0
- data/lib/karafka/web/pro/ui/views/explorer/{topic → explorer/topic}/_limited.erb +3 -0
- data/lib/karafka/web/pro/ui/views/explorer/{topic.erb → explorer/topic.erb} +7 -4
- data/lib/karafka/web/pro/ui/views/explorer/messages/_breadcrumbs.erb +32 -0
- data/lib/karafka/web/pro/ui/views/explorer/messages/forward.erb +143 -0
- data/lib/karafka/web/pro/ui/views/explorer/search/_breadcrumbs.erb +4 -0
- data/lib/karafka/web/pro/ui/views/explorer/search/_fix_errors.erb +6 -0
- data/lib/karafka/web/pro/ui/views/{search → explorer/search}/_metadata.erb +3 -0
- data/lib/karafka/web/pro/ui/views/explorer/search/_no_results.erb +6 -0
- data/lib/karafka/web/pro/ui/views/{search → explorer/search}/_no_search_criteria.erb +3 -0
- data/lib/karafka/web/pro/ui/views/{search → explorer/search}/_search_criteria.erb +3 -0
- data/lib/karafka/web/pro/ui/views/{search → explorer/search}/_search_modal.erb +5 -2
- data/lib/karafka/web/pro/ui/views/explorer/search/_timeout.erb +6 -0
- data/lib/karafka/web/pro/ui/views/explorer/search/index.erb +32 -0
- data/lib/karafka/web/pro/ui/views/health/_breadcrumbs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/health/_no_data.erb +3 -0
- data/lib/karafka/web/pro/ui/views/health/_partition.erb +16 -1
- data/lib/karafka/web/pro/ui/views/health/_partition_lags.erb +3 -0
- data/lib/karafka/web/pro/ui/views/health/_partition_offset.erb +3 -0
- data/lib/karafka/web/pro/ui/views/health/_partition_times.erb +3 -0
- data/lib/karafka/web/pro/ui/views/health/_table_metadata.erb +4 -1
- data/lib/karafka/web/pro/ui/views/health/_tabs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/health/changes.erb +4 -1
- data/lib/karafka/web/pro/ui/views/health/cluster_lags.erb +3 -0
- data/lib/karafka/web/pro/ui/views/health/lags.erb +5 -2
- data/lib/karafka/web/pro/ui/views/health/offsets.erb +4 -1
- data/lib/karafka/web/pro/ui/views/health/overview.erb +8 -3
- data/lib/karafka/web/pro/ui/views/jobs/_job.erb +50 -38
- data/lib/karafka/web/pro/ui/views/jobs/_no_jobs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/jobs/pending.erb +4 -1
- data/lib/karafka/web/pro/ui/views/jobs/running.erb +4 -1
- data/lib/karafka/web/pro/ui/views/recurring_tasks/_actions.erb +3 -0
- data/lib/karafka/web/pro/ui/views/recurring_tasks/_batch_actions.erb +3 -0
- data/lib/karafka/web/pro/ui/views/recurring_tasks/_breadcrumbs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/recurring_tasks/_log.erb +3 -0
- data/lib/karafka/web/pro/ui/views/recurring_tasks/_not_active.erb +3 -0
- data/lib/karafka/web/pro/ui/views/recurring_tasks/_tabs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/recurring_tasks/_task.erb +3 -0
- data/lib/karafka/web/pro/ui/views/recurring_tasks/logs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/recurring_tasks/schedule.erb +3 -0
- data/lib/karafka/web/pro/ui/views/routing/_consumer_group.erb +3 -0
- data/lib/karafka/web/pro/ui/views/routing/_detail.erb +3 -0
- data/lib/karafka/web/pro/ui/views/routing/_topic.erb +3 -0
- data/lib/karafka/web/pro/ui/views/routing/index.erb +3 -0
- data/lib/karafka/web/pro/ui/views/routing/show.erb +3 -0
- data/lib/karafka/web/pro/ui/views/scheduled_messages/explorer/_breadcrumbs.erb +6 -3
- data/lib/karafka/web/pro/ui/views/scheduled_messages/explorer/_key.erb +3 -0
- data/lib/karafka/web/pro/ui/views/scheduled_messages/explorer/_message.erb +4 -1
- data/lib/karafka/web/pro/ui/views/scheduled_messages/explorer/_messages.erb +3 -0
- data/lib/karafka/web/pro/ui/views/scheduled_messages/explorer/partition.erb +23 -16
- data/lib/karafka/web/pro/ui/views/scheduled_messages/explorer/topic.erb +6 -3
- data/lib/karafka/web/pro/ui/views/scheduled_messages/schedules/_breadcrumbs.erb +3 -0
- data/lib/karafka/web/pro/ui/views/scheduled_messages/schedules/_no_groups.erb +3 -0
- data/lib/karafka/web/pro/ui/views/scheduled_messages/schedules/index.erb +4 -1
- data/lib/karafka/web/pro/ui/views/scheduled_messages/schedules/show.erb +3 -0
- data/lib/karafka/web/pro/ui/views/shared/_navigation.erb +25 -17
- data/lib/karafka/web/pro/ui/views/shared/_rdkafka_form_error_alert_box.erb +16 -0
- data/lib/karafka/web/pro/ui/views/shared/branding/_label.erb +3 -0
- data/lib/karafka/web/pro/ui/views/shared/branding/_notice.erb +3 -0
- data/lib/karafka/web/pro/ui/views/topics/configs/_breadcrumbs.erb +34 -0
- data/lib/karafka/web/pro/ui/views/topics/configs/_config.erb +26 -0
- data/lib/karafka/web/pro/ui/views/topics/configs/_delete_button.erb +13 -0
- data/lib/karafka/web/pro/ui/views/topics/configs/_edit_form.erb +50 -0
- data/lib/karafka/web/pro/ui/views/topics/configs/_edit_plan.erb +16 -0
- data/lib/karafka/web/pro/ui/views/topics/configs/_edit_warning.erb +12 -0
- data/lib/karafka/web/pro/ui/views/topics/configs/edit.erb +16 -0
- data/lib/karafka/web/pro/ui/views/topics/{config.erb → configs/index.erb} +9 -3
- data/lib/karafka/web/pro/ui/views/topics/distributions/_add_partitions_button.erb +13 -0
- data/lib/karafka/web/pro/ui/views/topics/{distribution → distributions}/_badges.erb +3 -0
- data/lib/karafka/web/pro/ui/views/topics/distributions/_breadcrumbs.erb +28 -0
- data/lib/karafka/web/pro/ui/views/topics/{distribution → distributions}/_chart.erb +3 -0
- data/lib/karafka/web/pro/ui/views/topics/distributions/_edit_form.erb +47 -0
- data/lib/karafka/web/pro/ui/views/topics/distributions/_edit_hints.erb +15 -0
- data/lib/karafka/web/pro/ui/views/topics/distributions/_edit_warnings.erb +14 -0
- data/lib/karafka/web/pro/ui/views/topics/distributions/_empty_partitions.erb +4 -0
- data/lib/karafka/web/pro/ui/views/topics/{distribution → distributions}/_limited.erb +3 -0
- data/lib/karafka/web/pro/ui/views/topics/distributions/_partition.erb +13 -0
- data/lib/karafka/web/pro/ui/views/topics/distributions/edit.erb +16 -0
- data/lib/karafka/web/pro/ui/views/topics/{distribution.erb → distributions/show.erb} +11 -7
- data/lib/karafka/web/pro/ui/views/topics/offsets/_breadcrumbs.erb +20 -0
- data/lib/karafka/web/pro/ui/views/topics/offsets/_partition.erb +13 -0
- data/lib/karafka/web/pro/ui/views/topics/{offsets.erb → offsets/show.erb} +6 -3
- data/lib/karafka/web/pro/ui/views/topics/replications/_breadcrumbs.erb +20 -0
- data/lib/karafka/web/pro/ui/views/topics/{_partition.erb → replications/_partition.erb} +4 -1
- data/lib/karafka/web/pro/ui/views/topics/{replication.erb → replications/show.erb} +6 -3
- data/lib/karafka/web/pro/ui/views/topics/topics/_breadcrumbs.erb +32 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/_create_button.erb +13 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/_create_hints.erb +15 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/_delete_form.erb +36 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/_delete_hints.erb +15 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/_delete_warning.erb +13 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/_new_form.erb +80 -0
- data/lib/karafka/web/pro/ui/views/topics/{_tabs.erb → topics/_tabs.erb} +7 -4
- data/lib/karafka/web/pro/ui/views/topics/topics/_topic.erb +12 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/edit.erb +10 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/index.erb +19 -0
- data/lib/karafka/web/pro/ui/views/topics/topics/new.erb +12 -0
- data/lib/karafka/web/processing/consumers/metrics.rb +1 -1
- data/lib/karafka/web/processing/consumers/state.rb +1 -1
- data/lib/karafka/web/processing/publisher.rb +4 -4
- data/lib/karafka/web/tracking/consumers/contracts/partition.rb +1 -0
- data/lib/karafka/web/tracking/consumers/listeners/pausing.rb +2 -2
- data/lib/karafka/web/tracking/consumers/listeners/transactions.rb +44 -0
- data/lib/karafka/web/tracking/consumers/reporter.rb +2 -2
- data/lib/karafka/web/tracking/consumers/sampler.rb +81 -14
- data/lib/karafka/web/tracking/helpers/sysconf.rb +33 -0
- data/lib/karafka/web/tracking/producers/reporter.rb +1 -1
- data/lib/karafka/web/ui/app.rb +19 -112
- data/lib/karafka/web/ui/base.rb +63 -4
- data/lib/karafka/web/ui/controllers/base_controller.rb +43 -1
- data/lib/karafka/web/ui/controllers/cluster_controller.rb +5 -2
- data/lib/karafka/web/ui/controllers/errors_controller.rb +1 -1
- data/lib/karafka/web/ui/controllers/requests/execution_wrapper.rb +52 -0
- data/lib/karafka/web/ui/controllers/requests/hookable.rb +99 -0
- data/lib/karafka/web/ui/controllers/requests/params.rb +39 -1
- data/lib/karafka/web/ui/controllers/responses/redirect.rb +0 -5
- data/lib/karafka/web/ui/controllers/status_controller.rb +3 -0
- data/lib/karafka/web/ui/helpers/application_helper.rb +10 -1
- data/lib/karafka/web/ui/helpers/paths_helper.rb +54 -10
- data/lib/karafka/web/ui/lib/admin.rb +1 -1
- data/lib/karafka/web/ui/lib/cache.rb +135 -0
- data/lib/karafka/web/ui/models/broker.rb +1 -2
- data/lib/karafka/web/ui/models/cluster_info.rb +15 -21
- data/lib/karafka/web/ui/models/consumers_metrics.rb +1 -1
- data/lib/karafka/web/ui/models/consumers_state.rb +1 -1
- data/lib/karafka/web/ui/models/counters.rb +1 -1
- data/lib/karafka/web/ui/models/health.rb +9 -7
- data/lib/karafka/web/ui/models/process.rb +14 -0
- data/lib/karafka/web/ui/models/processes.rb +2 -2
- data/lib/karafka/web/ui/models/recurring_tasks/schedule.rb +1 -1
- data/lib/karafka/web/ui/models/status.rb +27 -8
- data/lib/karafka/web/ui/models/topic.rb +1 -2
- data/lib/karafka/web/ui/public/javascripts/application.js +8 -98
- data/lib/karafka/web/ui/public/javascripts/application.min.js +12 -4
- data/lib/karafka/web/ui/public/javascripts/application.min.js.br +0 -0
- data/lib/karafka/web/ui/public/javascripts/application.min.js.gz +0 -0
- data/lib/karafka/web/ui/public/javascripts/components/action_confirmation_manager.js +30 -0
- data/lib/karafka/web/ui/public/javascripts/components/alerts.js +39 -0
- data/lib/karafka/web/ui/public/javascripts/components/button_lock_manager.js +50 -0
- data/lib/karafka/web/ui/public/javascripts/components/live_poll.js +71 -19
- data/lib/karafka/web/ui/public/javascripts/components/message_republish_manager.js +50 -0
- data/lib/karafka/web/ui/public/javascripts/components/page_title_tracker.js +21 -0
- data/lib/karafka/web/ui/public/javascripts/components/partition_redirect_manager.js +21 -0
- data/lib/karafka/web/ui/public/javascripts/components/time_ago_manager.js +25 -0
- data/lib/karafka/web/ui/public/javascripts/components/timestamp_selector.js +30 -0
- data/lib/karafka/web/ui/public/javascripts/libs/datepicker.js +2 -2
- data/lib/karafka/web/ui/public/stylesheets/application.css +30 -0
- data/lib/karafka/web/ui/public/stylesheets/application.min.css +5122 -13
- data/lib/karafka/web/ui/public/stylesheets/application.min.css.br +0 -0
- data/lib/karafka/web/ui/public/stylesheets/application.min.css.gz +0 -0
- data/lib/karafka/web/ui/public/stylesheets/libs/highlight_dark.min.css.gz +0 -0
- data/lib/karafka/web/ui/public/stylesheets/libs/highlight_light.min.css.gz +0 -0
- data/lib/karafka/web/ui/public/stylesheets/libs/tailwind.css +512 -213
- data/lib/karafka/web/ui/routes/assets.rb +53 -0
- data/lib/karafka/web/ui/routes/base.rb +36 -0
- data/lib/karafka/web/ui/routes/cluster.rb +28 -0
- data/lib/karafka/web/ui/routes/consumers.rb +35 -0
- data/lib/karafka/web/ui/routes/dashboard.rb +20 -0
- data/lib/karafka/web/ui/routes/errors.rb +26 -0
- data/lib/karafka/web/ui/routes/jobs.rb +28 -0
- data/lib/karafka/web/ui/routes/pro_only.rb +27 -0
- data/lib/karafka/web/ui/routes/routing.rb +26 -0
- data/lib/karafka/web/ui/routes/status.rb +19 -0
- data/lib/karafka/web/ui/routes/support.rb +19 -0
- data/lib/karafka/web/ui/routes/ux.rb +19 -0
- data/lib/karafka/web/ui/views/cluster/_partition.erb +2 -2
- data/lib/karafka/web/ui/views/cluster/brokers.erb +1 -1
- data/lib/karafka/web/ui/views/consumers/_breadcrumbs.erb +7 -1
- data/lib/karafka/web/ui/views/consumers/_consumer.erb +39 -30
- data/lib/karafka/web/ui/views/consumers/_incompatible.erb +13 -0
- data/lib/karafka/web/ui/views/consumers/_no_consumers.erb +2 -2
- data/lib/karafka/web/ui/views/consumers/_tabs.erb +4 -4
- data/lib/karafka/web/ui/views/consumers/index.erb +1 -1
- data/lib/karafka/web/ui/views/dashboard/_feature_pro.erb +1 -1
- data/lib/karafka/web/ui/views/dashboard/_not_enough_data.erb +2 -2
- data/lib/karafka/web/ui/views/dashboard/_ranges_selector.erb +1 -1
- data/lib/karafka/web/ui/views/dashboard/index.erb +6 -49
- data/lib/karafka/web/ui/views/errors/_detail.erb +3 -3
- data/lib/karafka/web/ui/views/errors/index.erb +1 -1
- data/lib/karafka/web/ui/views/jobs/_job.erb +38 -29
- data/lib/karafka/web/ui/views/jobs/pending.erb +1 -1
- data/lib/karafka/web/ui/views/jobs/running.erb +1 -1
- data/lib/karafka/web/ui/views/layout.erb +7 -5
- data/lib/karafka/web/ui/views/shared/_become_pro.erb +1 -1
- data/lib/karafka/web/ui/views/shared/_brand.erb +1 -1
- data/lib/karafka/web/ui/views/shared/_breadcrumbs.erb +1 -1
- data/lib/karafka/web/ui/views/shared/_content.erb +1 -1
- data/lib/karafka/web/ui/views/shared/_controls.erb +10 -3
- data/lib/karafka/web/ui/views/shared/_custom_nav.erb +9 -0
- data/lib/karafka/web/ui/views/shared/_flashes.erb +3 -5
- data/lib/karafka/web/ui/views/shared/_header.erb +25 -2
- data/lib/karafka/web/ui/views/shared/_navigation.erb +17 -15
- data/lib/karafka/web/ui/views/shared/alerts/_error.erb +8 -0
- data/lib/karafka/web/ui/views/shared/alerts/_info.erb +8 -0
- data/lib/karafka/web/ui/views/shared/alerts/_primary.erb +8 -0
- data/lib/karafka/web/ui/views/shared/alerts/_secondary.erb +8 -0
- data/lib/karafka/web/ui/views/shared/alerts/_success.erb +8 -0
- data/lib/karafka/web/ui/views/shared/alerts/_warning.erb +8 -0
- data/lib/karafka/web/ui/views/shared/exceptions/incompatible_schema.erb +34 -0
- data/lib/karafka/web/ui/views/shared/exceptions/not_allowed.erb +4 -0
- data/lib/karafka/web/ui/views/shared/exceptions/not_found.erb +5 -1
- data/lib/karafka/web/ui/views/shared/exceptions/pro_only.erb +4 -0
- data/lib/karafka/web/ui/views/shared/icons/_arrow_left.erb +3 -0
- data/lib/karafka/web/ui/views/shared/icons/_arrow_up_tray.erb +3 -0
- data/lib/karafka/web/ui/views/shared/icons/_clock.erb +3 -0
- data/lib/karafka/web/ui/views/shared/icons/_pencil.erb +3 -0
- data/lib/karafka/web/ui/views/shared/icons/_pencil_square.erb +3 -0
- data/lib/karafka/web/ui/views/shared/icons/_play_pause.erb +3 -0
- data/lib/karafka/web/ui/views/shared/icons/_plus.erb +3 -0
- data/lib/karafka/web/ui/views/shared/icons/_trash.erb +3 -0
- data/lib/karafka/web/ui/views/status/failures/_live_reporting.erb +1 -1
- data/lib/karafka/web/ui/views/status/failures/_partitions.erb +3 -3
- data/lib/karafka/web/ui/views/status/failures/_state_calculation.erb +2 -2
- data/lib/karafka/web/ui/views/status/info/_components.erb +6 -6
- data/lib/karafka/web/ui/views/status/show.erb +15 -0
- data/lib/karafka/web/ui/views/status/warnings/_consumers_schemas.erb +31 -0
- data/lib/karafka/web/ui/views/ux/_icons.erb +1 -1
- data/lib/karafka/web/ui/views/ux/_status_rows.erb +6 -0
- data/lib/karafka/web/version.rb +1 -1
- data/lib/karafka/web.rb +3 -0
- data/package-lock.json +776 -1208
- data/package.json +3 -4
- data/postcss.config.js +1 -2
- data/renovate.json +13 -1
- data/tailwind.config.js +0 -4
- data.tar.gz.sig +0 -0
- metadata +232 -108
- metadata.gz.sig +0 -0
- data/lib/karafka/web/pro/commanding/commands/quiet.rb +0 -34
- data/lib/karafka/web/pro/commanding/commands/stop.rb +0 -34
- data/lib/karafka/web/pro/commanding/commands/trace.rb +0 -41
- data/lib/karafka/web/pro/ui/controllers/commanding_controller.rb +0 -118
- data/lib/karafka/web/pro/ui/controllers/commands_controller.rb +0 -96
- data/lib/karafka/web/pro/ui/controllers/consumers_controller.rb +0 -138
- data/lib/karafka/web/pro/ui/controllers/explorer_controller.rb +0 -220
- data/lib/karafka/web/pro/ui/controllers/messages_controller.rb +0 -107
- data/lib/karafka/web/pro/ui/controllers/search_controller.rb +0 -73
- data/lib/karafka/web/pro/ui/controllers/topics_controller.rb +0 -130
- data/lib/karafka/web/pro/ui/views/commands/_breadcrumbs.erb +0 -21
- data/lib/karafka/web/pro/ui/views/commands/_command_details.erb +0 -1
- data/lib/karafka/web/pro/ui/views/commands/_empty.erb +0 -3
- data/lib/karafka/web/pro/ui/views/commands/show.erb +0 -33
- data/lib/karafka/web/pro/ui/views/consumers/_breadcrumbs.erb +0 -55
- data/lib/karafka/web/pro/ui/views/consumers/_consumer.erb +0 -47
- data/lib/karafka/web/pro/ui/views/consumers/_consumer_controls.erb +0 -95
- data/lib/karafka/web/pro/ui/views/consumers/_consumer_performance.erb +0 -59
- data/lib/karafka/web/pro/ui/views/consumers/_tabs.erb +0 -33
- data/lib/karafka/web/pro/ui/views/consumers/consumer/_commands.erb +0 -72
- data/lib/karafka/web/pro/ui/views/consumers/consumer/_consumer_group.erb +0 -8
- data/lib/karafka/web/pro/ui/views/consumers/consumer/_no_subscriptions.erb +0 -7
- data/lib/karafka/web/pro/ui/views/consumers/details.erb +0 -13
- data/lib/karafka/web/pro/ui/views/consumers/subscriptions.erb +0 -25
- data/lib/karafka/web/pro/ui/views/explorer/_no_topics.erb +0 -1
- data/lib/karafka/web/pro/ui/views/explorer/_topic.erb +0 -10
- data/lib/karafka/web/pro/ui/views/explorer/index.erb +0 -14
- data/lib/karafka/web/pro/ui/views/explorer/messages/_headers.erb +0 -33
- data/lib/karafka/web/pro/ui/views/explorer/partition/_cleaned.erb +0 -3
- data/lib/karafka/web/pro/ui/views/explorer/partition/_empty.erb +0 -3
- data/lib/karafka/web/pro/ui/views/explorer/topic/_empty.erb +0 -3
- data/lib/karafka/web/pro/ui/views/search/_breadcrumbs.erb +0 -1
- data/lib/karafka/web/pro/ui/views/search/_fix_errors.erb +0 -3
- data/lib/karafka/web/pro/ui/views/search/_no_results.erb +0 -3
- data/lib/karafka/web/pro/ui/views/search/_timeout.erb +0 -3
- data/lib/karafka/web/pro/ui/views/search/index.erb +0 -29
- data/lib/karafka/web/pro/ui/views/topics/_breadcrumbs.erb +0 -45
- data/lib/karafka/web/pro/ui/views/topics/_partition_offsets.erb +0 -10
- data/lib/karafka/web/pro/ui/views/topics/_topic.erb +0 -9
- data/lib/karafka/web/pro/ui/views/topics/distribution/_empty_partitions.erb +0 -1
- data/lib/karafka/web/pro/ui/views/topics/distribution/_partition.erb +0 -10
- data/lib/karafka/web/pro/ui/views/topics/index.erb +0 -14
- data/lib/karafka/web/ui/lib/ttl_cache.rb +0 -82
@@ -1,107 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
# This Karafka component is a Pro component under a commercial license.
|
4
|
-
# This Karafka component is NOT licensed under LGPL.
|
5
|
-
#
|
6
|
-
# All of the commercial components are present in the lib/karafka/pro directory of this
|
7
|
-
# repository and their usage requires commercial license agreement.
|
8
|
-
#
|
9
|
-
# Karafka has also commercial-friendly license, commercial support and commercial components.
|
10
|
-
#
|
11
|
-
# By sending a pull request to the pro components, you are agreeing to transfer the copyright of
|
12
|
-
# your code to Maciej Mensfeld.
|
13
|
-
|
14
|
-
module Karafka
|
15
|
-
module Web
|
16
|
-
module Pro
|
17
|
-
module Ui
|
18
|
-
module Controllers
|
19
|
-
# Controller for working with messages
|
20
|
-
# While part of messages operations is done via explorer (exploring), this controller
|
21
|
-
# handles other cases not related to viewing data
|
22
|
-
class MessagesController < BaseController
|
23
|
-
# Takes a requested message content and republishes it again
|
24
|
-
#
|
25
|
-
# @param topic_id [String]
|
26
|
-
# @param partition_id [Integer]
|
27
|
-
# @param offset [Integer] offset of the message we want to republish
|
28
|
-
def republish(topic_id, partition_id, offset)
|
29
|
-
message = Models::Message.find(topic_id, partition_id, offset)
|
30
|
-
|
31
|
-
deny! unless visibility_filter.republish?(message)
|
32
|
-
|
33
|
-
delivery = ::Karafka::Web.producer.produce_sync(
|
34
|
-
topic: topic_id,
|
35
|
-
partition: partition_id,
|
36
|
-
payload: message.raw_payload,
|
37
|
-
headers: message.headers,
|
38
|
-
key: message.key
|
39
|
-
)
|
40
|
-
|
41
|
-
redirect(
|
42
|
-
:back,
|
43
|
-
success: reproduced(message, delivery)
|
44
|
-
)
|
45
|
-
end
|
46
|
-
|
47
|
-
# Dispatches the message raw payload to the browser as a file
|
48
|
-
#
|
49
|
-
# @param topic_id [String]
|
50
|
-
# @param partition_id [Integer]
|
51
|
-
# @param offset [Integer] offset of the message we want to download
|
52
|
-
def download(topic_id, partition_id, offset)
|
53
|
-
message = Models::Message.find(topic_id, partition_id, offset)
|
54
|
-
|
55
|
-
deny! unless visibility_filter.download?(message)
|
56
|
-
|
57
|
-
file(
|
58
|
-
message.raw_payload,
|
59
|
-
"#{topic_id}_#{partition_id}_#{offset}_payload.msg"
|
60
|
-
)
|
61
|
-
end
|
62
|
-
|
63
|
-
# Dispatches the message payload first deserialized and then serialized to JSON
|
64
|
-
# It differs from the raw payload in cases where raw payload is compressed or binary
|
65
|
-
# or contains data that the Web UI user should not see that was altered on the Web UI
|
66
|
-
# with the visibility filter.
|
67
|
-
#
|
68
|
-
# @param topic_id [String]
|
69
|
-
# @param partition_id [Integer]
|
70
|
-
# @param offset [Integer] offset of the message we want to export
|
71
|
-
def export(topic_id, partition_id, offset)
|
72
|
-
Lib::PatternsDetector.new.call
|
73
|
-
|
74
|
-
message = Models::Message.find(topic_id, partition_id, offset)
|
75
|
-
|
76
|
-
# Check if exports are allowed
|
77
|
-
deny! unless visibility_filter.export?(message)
|
78
|
-
|
79
|
-
file(
|
80
|
-
message.payload.to_json,
|
81
|
-
"#{topic_id}_#{partition_id}_#{offset}_payload.json"
|
82
|
-
)
|
83
|
-
end
|
84
|
-
|
85
|
-
private
|
86
|
-
|
87
|
-
# @param message [Karafka::Messages::Message]
|
88
|
-
# @param delivery [Rdkafka::Producer::DeliveryReport]
|
89
|
-
# @return [String] flash message about message reproducing
|
90
|
-
def reproduced(message, delivery)
|
91
|
-
<<~MSG
|
92
|
-
Message with offset #{message.offset}
|
93
|
-
has been sent again to #{message.topic}##{message.partition}
|
94
|
-
and received offset #{delivery.offset}.
|
95
|
-
MSG
|
96
|
-
end
|
97
|
-
|
98
|
-
# @return [Object] visibility filter. Either default or user-based
|
99
|
-
def visibility_filter
|
100
|
-
::Karafka::Web.config.ui.policies.messages
|
101
|
-
end
|
102
|
-
end
|
103
|
-
end
|
104
|
-
end
|
105
|
-
end
|
106
|
-
end
|
107
|
-
end
|
@@ -1,73 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
# This Karafka component is a Pro component under a commercial license.
|
4
|
-
# This Karafka component is NOT licensed under LGPL.
|
5
|
-
#
|
6
|
-
# All of the commercial components are present in the lib/karafka/pro directory of this
|
7
|
-
# repository and their usage requires commercial license agreement.
|
8
|
-
#
|
9
|
-
# Karafka has also commercial-friendly license, commercial support and commercial components.
|
10
|
-
#
|
11
|
-
# By sending a pull request to the pro components, you are agreeing to transfer the copyright of
|
12
|
-
# your code to Maciej Mensfeld.
|
13
|
-
|
14
|
-
module Karafka
|
15
|
-
module Web
|
16
|
-
module Pro
|
17
|
-
module Ui
|
18
|
-
module Controllers
|
19
|
-
# Handles the search requests
|
20
|
-
# We present this as a part of explorer scope but we use a separate controller not to
|
21
|
-
# mix data exploring with searching.
|
22
|
-
class SearchController < Web::Ui::Controllers::ClusterController
|
23
|
-
# Runs the search if search parameters are provided
|
24
|
-
# If no parameters provided, displays the search modal and info to provide search data
|
25
|
-
# If invalid search parameters provided, modal contains errors
|
26
|
-
#
|
27
|
-
# @param topic_id [String] topic we're interested in
|
28
|
-
# @note In theory search can be used to detect pieces of information within messages.
|
29
|
-
# Since we allow for custom search strategies, this is not an issue because users
|
30
|
-
# that need to provide only granular search can do so.
|
31
|
-
def index(topic_id)
|
32
|
-
@topic_id = topic_id
|
33
|
-
@partitions_count = Models::ClusterInfo.partitions_count(topic_id)
|
34
|
-
# Select only matchers that should be available in the context of the current topic
|
35
|
-
@matchers = Web.config.ui.search.matchers.select { |match| match.active?(@topic_id) }
|
36
|
-
@search_criteria = !@params.current_search.empty?
|
37
|
-
@current_search = Lib::Search::Normalizer.call(@params.current_search)
|
38
|
-
# Needed when rendering found messages rows. We should always filter the messages
|
39
|
-
# details with the visibility filter
|
40
|
-
@visibility_filter = ::Karafka::Web.config.ui.policies.messages
|
41
|
-
@limits = ::Karafka::Web.config.ui.search.limits.sort
|
42
|
-
|
43
|
-
# If there is search form filled, we validate it to make sure there are no errors
|
44
|
-
@errors = if @search_criteria
|
45
|
-
Lib::Search::Contracts::Form.new.call(@current_search).errors
|
46
|
-
else
|
47
|
-
{}
|
48
|
-
end
|
49
|
-
|
50
|
-
# If all good we run the search
|
51
|
-
if @search_criteria && @errors.empty?
|
52
|
-
found, @search_details = Lib::Search::Runner.new(
|
53
|
-
@topic_id,
|
54
|
-
@partitions_count,
|
55
|
-
@current_search
|
56
|
-
).call
|
57
|
-
|
58
|
-
@messages, last_page = Paginators::Arrays.call(
|
59
|
-
found,
|
60
|
-
@params.current_page
|
61
|
-
)
|
62
|
-
|
63
|
-
paginate(@params.current_page, !last_page)
|
64
|
-
end
|
65
|
-
|
66
|
-
render
|
67
|
-
end
|
68
|
-
end
|
69
|
-
end
|
70
|
-
end
|
71
|
-
end
|
72
|
-
end
|
73
|
-
end
|
@@ -1,130 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
# This Karafka component is a Pro component under a commercial license.
|
4
|
-
# This Karafka component is NOT licensed under LGPL.
|
5
|
-
#
|
6
|
-
# All of the commercial components are present in the lib/karafka/pro directory of this
|
7
|
-
# repository and their usage requires commercial license agreement.
|
8
|
-
#
|
9
|
-
# Karafka has also commercial-friendly license, commercial support and commercial components.
|
10
|
-
#
|
11
|
-
# By sending a pull request to the pro components, you are agreeing to transfer the copyright of
|
12
|
-
# your code to Maciej Mensfeld.
|
13
|
-
|
14
|
-
module Karafka
|
15
|
-
module Web
|
16
|
-
module Pro
|
17
|
-
module Ui
|
18
|
-
module Controllers
|
19
|
-
# Topics management controller
|
20
|
-
# Allows for exploration of settings and replication details
|
21
|
-
class TopicsController < BaseController
|
22
|
-
self.sortable_attributes = %w[
|
23
|
-
name
|
24
|
-
value
|
25
|
-
default?
|
26
|
-
read_only?
|
27
|
-
synonym?
|
28
|
-
sensitive?
|
29
|
-
partition_id
|
30
|
-
leader
|
31
|
-
replica_count
|
32
|
-
in_sync_replica_brokers
|
33
|
-
count
|
34
|
-
share
|
35
|
-
diff
|
36
|
-
low
|
37
|
-
high
|
38
|
-
].freeze
|
39
|
-
|
40
|
-
# Lists available topics in the cluster
|
41
|
-
def index
|
42
|
-
@topics = Models::Topic.all.sort_by(&:topic_name)
|
43
|
-
|
44
|
-
unless ::Karafka::Web.config.ui.visibility.internal_topics
|
45
|
-
@topics.delete_if { |topic| topic[:topic_name].start_with?('__') }
|
46
|
-
end
|
47
|
-
|
48
|
-
render
|
49
|
-
end
|
50
|
-
|
51
|
-
# Displays requested topic config details
|
52
|
-
#
|
53
|
-
# @param topic_name [String] topic we're interested in
|
54
|
-
def config(topic_name)
|
55
|
-
@topic = Models::Topic.find(topic_name)
|
56
|
-
|
57
|
-
@configs = refine(@topic.configs)
|
58
|
-
|
59
|
-
render
|
60
|
-
end
|
61
|
-
|
62
|
-
# Displays requested topic replication details
|
63
|
-
#
|
64
|
-
# @param topic_name [String] topic we're interested in
|
65
|
-
def replication(topic_name)
|
66
|
-
@topic = Models::Topic.find(topic_name)
|
67
|
-
|
68
|
-
@partitions = refine(@topic[:partitions])
|
69
|
-
|
70
|
-
render
|
71
|
-
end
|
72
|
-
|
73
|
-
# Displays the messages distribution across various partitions
|
74
|
-
#
|
75
|
-
# @param topic_name [String] topic we're interested in
|
76
|
-
#
|
77
|
-
# @note Because computing distribution is fairly expensive, we paginate this. While
|
78
|
-
# because of that results may not be exact, this allows us to support topics with
|
79
|
-
# many partitions.
|
80
|
-
def distribution(topic_name)
|
81
|
-
@topic = Models::Topic.find(topic_name)
|
82
|
-
|
83
|
-
@active_partitions, _materialized_page, @limited = Paginators::Partitions.call(
|
84
|
-
@topic.partition_count, @params.current_page
|
85
|
-
)
|
86
|
-
|
87
|
-
@aggregated, distribution = @topic.distribution(@active_partitions)
|
88
|
-
|
89
|
-
@distribution = refine(distribution)
|
90
|
-
|
91
|
-
next_page = @active_partitions.last < @topic.partition_count - 1
|
92
|
-
paginate(@params.current_page, next_page)
|
93
|
-
|
94
|
-
render
|
95
|
-
end
|
96
|
-
|
97
|
-
# Displays high and low offsets for given topic
|
98
|
-
#
|
99
|
-
# @param topic_name [String] topic we're interested in
|
100
|
-
def offsets(topic_name)
|
101
|
-
@topic = Models::Topic.find(topic_name)
|
102
|
-
|
103
|
-
@active_partitions, _materialized_page, @limited = Paginators::Partitions.call(
|
104
|
-
@topic.partition_count, @params.current_page
|
105
|
-
)
|
106
|
-
|
107
|
-
offsets = @active_partitions.map do |partition_id|
|
108
|
-
part_offsets = Admin.read_watermark_offsets(topic_name, partition_id)
|
109
|
-
|
110
|
-
{
|
111
|
-
partition_id: partition_id,
|
112
|
-
low: part_offsets.first,
|
113
|
-
high: part_offsets.last,
|
114
|
-
diff: part_offsets.last - part_offsets.first
|
115
|
-
}
|
116
|
-
end
|
117
|
-
|
118
|
-
@offsets = refine(offsets)
|
119
|
-
|
120
|
-
next_page = @active_partitions.last < @topic.partition_count - 1
|
121
|
-
paginate(@params.current_page, next_page)
|
122
|
-
|
123
|
-
render
|
124
|
-
end
|
125
|
-
end
|
126
|
-
end
|
127
|
-
end
|
128
|
-
end
|
129
|
-
end
|
130
|
-
end
|
@@ -1,21 +0,0 @@
|
|
1
|
-
<li>
|
2
|
-
<a href="<%= root_path('consumers/overview') %>">
|
3
|
-
Consumers
|
4
|
-
</a>
|
5
|
-
</li>
|
6
|
-
|
7
|
-
<% if current_path.include?('/commands') %>
|
8
|
-
<li>
|
9
|
-
<a href="<%= root_path('commands') %>">
|
10
|
-
Commands
|
11
|
-
</a>
|
12
|
-
</li>
|
13
|
-
<% end %>
|
14
|
-
|
15
|
-
<% if @command_message %>
|
16
|
-
<li>
|
17
|
-
<a href="<%= root_path('commands', @command_message.offset) %>">
|
18
|
-
<%= @command_message.offset %>
|
19
|
-
</a>
|
20
|
-
</li>
|
21
|
-
<% end %>
|
@@ -1 +0,0 @@
|
|
1
|
-
<pre class="code"><code class="json"><%= JSON.pretty_generate command %></code></pre>
|
@@ -1,33 +0,0 @@
|
|
1
|
-
<% command = @command_message.payload %>
|
2
|
-
|
3
|
-
<div class="col-span-12">
|
4
|
-
<% if command[:schema_version] == @schema_version %>
|
5
|
-
<% view_title "#{command[:command][:name]} #{command[:type]} #{@command_message.key}" %>
|
6
|
-
|
7
|
-
<%== partial 'consumers/tabs' %>
|
8
|
-
|
9
|
-
<%== partial 'commands/metadata', locals: { command: command } %>
|
10
|
-
|
11
|
-
<h2 class="h2">
|
12
|
-
<% if command[:type] == 'command' %>
|
13
|
-
Details
|
14
|
-
<% else %>
|
15
|
-
Backtraces
|
16
|
-
<% end %>
|
17
|
-
</h2>
|
18
|
-
|
19
|
-
<% if command[:type] == 'command' %>
|
20
|
-
<%== partial 'commands/command_details', locals: { command: command } %>
|
21
|
-
<% else %>
|
22
|
-
<% command[:result].each_value do |backtrace| %>
|
23
|
-
<%== partial 'commands/backtrace', locals: { backtrace: backtrace } %>
|
24
|
-
<% end %>
|
25
|
-
<% end %>
|
26
|
-
<% else %>
|
27
|
-
<% view_title 'Incompatible Command Schema' %>
|
28
|
-
|
29
|
-
<%== partial 'consumers/tabs' %>
|
30
|
-
|
31
|
-
<%== partial 'commands/incompatible_schema' %>
|
32
|
-
<% end %>
|
33
|
-
</div>
|
@@ -1,55 +0,0 @@
|
|
1
|
-
<li>
|
2
|
-
<a href="<%= root_path('consumers/overview') %>">
|
3
|
-
Consumers
|
4
|
-
</a>
|
5
|
-
</li>
|
6
|
-
|
7
|
-
<% if current_path.include?('/performance') %>
|
8
|
-
<li>
|
9
|
-
<a href="<%= root_path('consumers', 'performance') %>">
|
10
|
-
Performance
|
11
|
-
</a>
|
12
|
-
</li>
|
13
|
-
<% end %>
|
14
|
-
|
15
|
-
<% if current_path.include?('/controls') %>
|
16
|
-
<li>
|
17
|
-
<a href="<%= root_path('consumers', 'controls') %>">
|
18
|
-
Controls
|
19
|
-
</a>
|
20
|
-
</li>
|
21
|
-
<% end %>
|
22
|
-
|
23
|
-
<% if @process %>
|
24
|
-
<li>
|
25
|
-
<a href="<%= root_path('consumers', @process.id, 'subscriptions') %>">
|
26
|
-
<%== truncate(@process.id, strategy: :middle) %>
|
27
|
-
</a>
|
28
|
-
</li>
|
29
|
-
|
30
|
-
<% if current_path.include?('/jobs') %>
|
31
|
-
<li>
|
32
|
-
<a href="<%= root_path('consumers', @process.id, 'jobs') %>">
|
33
|
-
Jobs
|
34
|
-
</a>
|
35
|
-
</li>
|
36
|
-
|
37
|
-
<li>
|
38
|
-
<a href="<%= root_path('consumers', @process.id, 'jobs') %>">
|
39
|
-
Running
|
40
|
-
</a>
|
41
|
-
</li>
|
42
|
-
<% elsif current_path.include?('/subscriptions') %>
|
43
|
-
<li>
|
44
|
-
<a href="<%= root_path('consumers', @process.id, 'subscriptions') %>">
|
45
|
-
Subscriptions
|
46
|
-
</a>
|
47
|
-
</li>
|
48
|
-
<% else %>
|
49
|
-
<li>
|
50
|
-
<a href="<%= root_path('consumers', @process.id, 'details') %>">
|
51
|
-
Details
|
52
|
-
</a>
|
53
|
-
</li>
|
54
|
-
<% end %>
|
55
|
-
<% end %>
|
@@ -1,47 +0,0 @@
|
|
1
|
-
<tr class="status-row-<%= process.status %>">
|
2
|
-
<td>
|
3
|
-
<p>
|
4
|
-
<a href="<%= root_path('consumers', process.id, 'subscriptions') %>">
|
5
|
-
<%== truncate(process.id, strategy: :middle) %>
|
6
|
-
</a>
|
7
|
-
</p>
|
8
|
-
|
9
|
-
<p class="mt-1">
|
10
|
-
<%== partial 'consumers/assignments_badges', locals: { process: process } %>
|
11
|
-
</p>
|
12
|
-
|
13
|
-
<p>
|
14
|
-
<%== tags(process.tags) %>
|
15
|
-
</p>
|
16
|
-
</td>
|
17
|
-
|
18
|
-
<td>
|
19
|
-
<%== relative_time process.started_at %>
|
20
|
-
</td>
|
21
|
-
|
22
|
-
<td>
|
23
|
-
<%== badge_primary_sm format_memory process.memory_usage %>
|
24
|
-
<%== badge_primary_sm format_memory process.memory_total_usage %>
|
25
|
-
<%== badge_primary_sm format_memory process.memory_size %>
|
26
|
-
</td>
|
27
|
-
|
28
|
-
<td>
|
29
|
-
<span class="badge badge-primary">
|
30
|
-
<%= process.utilization.round(1) %>%
|
31
|
-
</span>
|
32
|
-
<span class="badge badge-primary">
|
33
|
-
<%= process.workers %> /
|
34
|
-
<%= process.busy %>
|
35
|
-
</span>
|
36
|
-
</td>
|
37
|
-
|
38
|
-
<td>
|
39
|
-
<% process.cpu_usage.each do |metric| %>
|
40
|
-
<%== badge_primary_sm metric %>
|
41
|
-
<% end %>
|
42
|
-
</td>
|
43
|
-
|
44
|
-
<td>
|
45
|
-
<%= process.lag_hybrid %>
|
46
|
-
</td>
|
47
|
-
</tr>
|
@@ -1,95 +0,0 @@
|
|
1
|
-
<tr class="status-row-<%= process.status %>">
|
2
|
-
<td>
|
3
|
-
<a href="<%= root_path('consumers', process.id, 'subscriptions') %>">
|
4
|
-
<%== truncate(process.id, strategy: :middle) %>
|
5
|
-
</a>
|
6
|
-
|
7
|
-
<p class="mt-1">
|
8
|
-
<%== tags(process.tags) %>
|
9
|
-
</p>
|
10
|
-
</td>
|
11
|
-
|
12
|
-
<td>
|
13
|
-
<div class="badge <%= status_badge(process.status) %>">
|
14
|
-
<%= process.status %>
|
15
|
-
</div>
|
16
|
-
</td>
|
17
|
-
|
18
|
-
<td>
|
19
|
-
<%== partial 'consumers/assignments_badges', locals: { process: process } %>
|
20
|
-
</td>
|
21
|
-
|
22
|
-
<td>
|
23
|
-
<%== relative_time process.started_at %>
|
24
|
-
</td>
|
25
|
-
|
26
|
-
<td>
|
27
|
-
<span class="badge badge-primary">
|
28
|
-
<%= format_memory process.memory_usage %>
|
29
|
-
</span>
|
30
|
-
</td>
|
31
|
-
|
32
|
-
<td>
|
33
|
-
<span class="badge badge-primary">
|
34
|
-
<%= process.utilization.round(1) %>%
|
35
|
-
</span>
|
36
|
-
<span class="badge badge-primary">
|
37
|
-
<%= process.workers %> /
|
38
|
-
<%= process.busy %>
|
39
|
-
</span>
|
40
|
-
</td>
|
41
|
-
|
42
|
-
<td>
|
43
|
-
<%= process.lag_hybrid %>
|
44
|
-
</td>
|
45
|
-
|
46
|
-
<td class="commands-inline-3">
|
47
|
-
<%
|
48
|
-
trace_path = root_path('commanding', process.id, 'trace')
|
49
|
-
disabled_class = process.status != 'stopped' ? '' : 'btn-disabled'
|
50
|
-
%>
|
51
|
-
<form action="<%= trace_path %>" method="post" class="inline" title="Trace">
|
52
|
-
<%== csrf_tag(trace_path) %>
|
53
|
-
|
54
|
-
<button type="submit" class="btn btn-info btn-sm <%= disabled_class %>">
|
55
|
-
<%== icon(:gear) %>
|
56
|
-
</button>
|
57
|
-
</form>
|
58
|
-
|
59
|
-
<%
|
60
|
-
quiet_path = root_path('commanding', process.id, 'quiet')
|
61
|
-
disabled_class = process.status == 'running' ? '' : 'btn-disabled'
|
62
|
-
|
63
|
-
if process.execution_mode == 'standalone'
|
64
|
-
title = 'Quiet'
|
65
|
-
else
|
66
|
-
disabled_class = 'btn-disabled'
|
67
|
-
title = 'Supported only in standalone consumer processes'
|
68
|
-
end
|
69
|
-
%>
|
70
|
-
<form action="<%= quiet_path %>" method="post" class="inline" title="<%= title %>">
|
71
|
-
<%== csrf_tag(quiet_path) %>
|
72
|
-
<button type="submit" class="btn btn-warning btn-sm <%= disabled_class %>">
|
73
|
-
<%== icon(:pause) %>
|
74
|
-
</button>
|
75
|
-
</form>
|
76
|
-
|
77
|
-
<%
|
78
|
-
stop_path = root_path('commanding', process.id, 'stop')
|
79
|
-
disabled_class = process.status != 'stopping' && process.status != 'stopped' ? '' : 'btn-disabled'
|
80
|
-
|
81
|
-
if process.execution_mode == 'standalone'
|
82
|
-
title = 'Stop'
|
83
|
-
else
|
84
|
-
disabled_class = 'btn-disabled'
|
85
|
-
title = 'Supported only in standalone consumer processes'
|
86
|
-
end
|
87
|
-
%>
|
88
|
-
<form action="<%= stop_path %>" method="post" class="inline" title="<%= title %>">
|
89
|
-
<%== csrf_tag(stop_path) %>
|
90
|
-
<button type="submit" class="btn btn-error btn-sm <%= disabled_class %>">
|
91
|
-
<%== icon(:stop) %>
|
92
|
-
</button>
|
93
|
-
</form>
|
94
|
-
</td>
|
95
|
-
</tr>
|
@@ -1,59 +0,0 @@
|
|
1
|
-
<tr class="status-row-<%= process.status %>">
|
2
|
-
<td>
|
3
|
-
<a href="<%= root_path('consumers', process.id, 'subscriptions') %>">
|
4
|
-
<%== truncate(process.id, strategy: :middle) %>
|
5
|
-
</a>
|
6
|
-
|
7
|
-
<p class="mt-1">
|
8
|
-
<%== tags(process.tags) %>
|
9
|
-
</p>
|
10
|
-
</td>
|
11
|
-
|
12
|
-
<td>
|
13
|
-
<%= format_memory process.memory_usage %>
|
14
|
-
</td>
|
15
|
-
|
16
|
-
<td>
|
17
|
-
<%= process.utilization.round(1) %>%
|
18
|
-
</td>
|
19
|
-
|
20
|
-
<td>
|
21
|
-
<%= process.threads %>
|
22
|
-
</td>
|
23
|
-
|
24
|
-
<td>
|
25
|
-
<%= process.cpu_usage[0].to_f %>
|
26
|
-
</td>
|
27
|
-
|
28
|
-
<td>
|
29
|
-
<%= process.cpu_usage[1].to_f %>
|
30
|
-
</td>
|
31
|
-
|
32
|
-
<td>
|
33
|
-
<%= process.cpu_usage[2].to_f %>
|
34
|
-
</td>
|
35
|
-
|
36
|
-
<td>
|
37
|
-
<%= process.workers %>
|
38
|
-
</td>
|
39
|
-
|
40
|
-
<td>
|
41
|
-
<%= process.busy %>
|
42
|
-
</td>
|
43
|
-
|
44
|
-
<td>
|
45
|
-
<%= process.listeners.fetch(:active) %>
|
46
|
-
</td>
|
47
|
-
|
48
|
-
<td>
|
49
|
-
<%= process.listeners.fetch(:standby) %>
|
50
|
-
</td>
|
51
|
-
|
52
|
-
<td>
|
53
|
-
<%= process.jobs.running.count %>
|
54
|
-
</td>
|
55
|
-
|
56
|
-
<td>
|
57
|
-
<%= process.jobs.pending.count %>
|
58
|
-
</td>
|
59
|
-
</tr>
|
@@ -1,33 +0,0 @@
|
|
1
|
-
<div class="tab-container-wrapper">
|
2
|
-
<div class="tab-container">
|
3
|
-
<a
|
4
|
-
href="<%= root_path('consumers', 'overview') %>"
|
5
|
-
class="custom-tab <%= nav_class(include: 'overview') %>"
|
6
|
-
>
|
7
|
-
Overview
|
8
|
-
</a>
|
9
|
-
|
10
|
-
<a
|
11
|
-
href="<%= root_path('consumers', 'performance') %>"
|
12
|
-
class="custom-tab <%= nav_class(include: 'performance') %>"
|
13
|
-
>
|
14
|
-
Performance
|
15
|
-
</a>
|
16
|
-
|
17
|
-
<% if Karafka::Web.config.commanding.active %>
|
18
|
-
<a
|
19
|
-
href="<%= root_path('consumers', 'controls') %>"
|
20
|
-
class="custom-tab <%= nav_class(include: 'controls') %>"
|
21
|
-
>
|
22
|
-
Controls
|
23
|
-
</a>
|
24
|
-
|
25
|
-
<a
|
26
|
-
href="<%= root_path('commands') %>"
|
27
|
-
class="custom-tab <%= nav_class(include: 'commands') %>"
|
28
|
-
>
|
29
|
-
Commands
|
30
|
-
</a>
|
31
|
-
<% end %>
|
32
|
-
</div>
|
33
|
-
</div>
|