opensearch-project / data-prepper
Components & Dependencies

An overview of source code logical components.

Intro

Logical decomposition is a representation of the organization of the main source code, where every and each file is put in exactly one logical component.

  • A software system can have one or more logical decompositions.
  • A logical decomposition can be defined in two ways in Sokrates.
  • First approach is based on the folders structure. Components are mapped to folders at defined folder depth relative to the source code root.
  • Second approach is based on explicit definition of each component. In such explicit definitions, components are explicitly named and their files are selected based on explicitly defined path and content filters.
  • A logical decomposition is considered invalid if a file is selected into two or more components.This constraint is introduced in order to facilitate measuring of dependencies among components.
  • Files not assigned to any component are put into a special "Unclassified" component.
Learn more...
Logical Decompositions Overview

Analyzed system has 1 logical decomposition:

  • primary (27 components)

Logical Decomposition #1: PRIMARY

The decompositions is based on the folder structure (relative to the source code root), with automatically defined folder depth to have at least 10 components.

Bubble Chart | Tree Map
Components
The "primary" logical decomposition has 27 components.
  • 247 files, 13,355 lines of code (72.9% vs. main code).
  • "data-prepper-core/src" is biggest, containing 15.63% of code.
  • "release/docker" is smallest, containing 0.07% of code.


data-prepper-core/src2088 LOC (11%) 39 files
data-prepper-api/src1669 LOC (9%) 45 files
data-prepper-plugins/opensearch1631 LOC (8%) 16 files
data-prepper-plugins/peer-forwarder977 LOC (5%) 19 files
data-prepper-plugins/common921 LOC (5%) 21 files
data-prepper-logstash-configuration/src888 LOC (4%) 31 files
data-prepper-plugins/otel-trace-raw-prepper738 LOC (4%) 9 files
e2e-test/trace600 LOC (3%) 7 files
data-prepper-plugins/service-map-stateful442 LOC (2%) 4 files
data-prepper-plugins/http-source437 LOC (2%) 9 files
data-prepper-plugins/otel-trace-source411 LOC (2%) 5 files
data-prepper-plugins/grok-prepper344 LOC (1%) 2 files
research/zipkin-opensearch-to-otel299 LOC (1%) 3 files
data-prepper-plugins/aggregate-processor252 LOC (1%) 12 files
data-prepper-plugins/otel-trace-group-prepper243 LOC (1%) 3 files
data-prepper-plugins/key-value-processor220 LOC (1%) 2 files
deployment-template/ec2216 LOC (1%) 1 files
e2e-test/log172 LOC (<1%) 4 files
data-prepper-benchmarks/service-map-stateful-benchmarks160 LOC (<1%) 1 files
data-prepper-plugins/armeria-common151 LOC (<1%) 7 files
data-prepper-plugins/blocking-buffer130 LOC (<1%) 1 files
deployment-template/k8s119 LOC (<1%) 1 files
data-prepper-plugins/mapdb-prepper-state112 LOC (<1%) 1 files
data-prepper-benchmarks/mapdb-benchmarks66 LOC (<1%) 1 files
data-prepper-plugins/drop-events-processor34 LOC (<1%) 1 files
deployment-template/eks25 LOC (<1%) 1 files
release/docker10 LOC (<1%) 1 files
Dependencies
Dependencies among components are static code dependencies among files in different components.

No component dependencies found.



2022-02-01 05:04