Class: ConvertSdk::SegmentsManager Private
- Inherits:
-
Object
- Object
- ConvertSdk::SegmentsManager
- Defined in:
- lib/convert_sdk/segments_manager.rb
Overview
This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.
Visitor segmentation — the REPORTING-data layer that attaches segment ids to a
visitor's StoreData in the JS SDK's wire shape (FR28–FR30). Ported from the
JS SDK packages/segments/src/segments-manager.ts; the PHP reference is
QUARANTINED here because it diverges on two wire keys.
PHP-divergence #2 — the wire-key quarantine (FR30)
JS SegmentsKeys (+segments-keys.ts:7-15+) emit camelCase:
visitorType / customSegments. PHP SegmentsKeys.php:14-15 emit snake_case:
visitor_type / custom_segments — a real, disk-verified divergence. Segment
data rides the tracking payload's segments object (Epic 4 ApiManager emits
the visitor's stored segments verbatim), so the wrong key would silently
mis-filter every Ruby segment-report. Ruby follows JS: the seven report-segment
keys, and customSegments in particular, are the ONLY ones persisted, as
camelCase STRINGS at rest in StoreData. The SegmentsManager never produces
the PHP variants; Story 3.2's quarantine spec asserts their absence.
The report-segment filter (#filter_report_segments, data-manager.ts:1180-1199)
Exactly seven keys are report-segments: country, browser, devices,
source, campaign, visitorType, customSegments. #put_segments keeps
ONLY these; every other key is silently DROPPED (JS routes them to a separate
properties bucket the segments layer ignores) — IGNORE, not reject. Ruby adds
a debug line naming the dropped keys (an observability addition; JS drops
silently). A filter that leaves NOTHING is a no-op write (JS if (reportSegments)).
Custom-segment evaluation REUSES the rule engine (#select_custom_segments)
run_custom_segments does NOT introduce new rule logic. For each requested
segment key it looks up the ConfigSegment entity (DataManager segments
reader), evaluates that segment's rules against the supplied
segment_rule data via RuleManager#is_rule_matched (so NEED_MORE_DATA and
every operator semantic come for FREE), and — on a match — appends the
segment's id to the visitor's stored customSegments list (deduped). A
surfaced RuleError sentinel propagates out verbatim (mirrors JS
+setCustomSegments+'s Object.values(RuleError).includes(...) early-return).
Persistence
All writes flow through the DataStoreManager atomic visitor-data merge
(Story 2.1) into StoreData["segments"]. Stored data is string-keyed
wire-world by design (so Epic 4's payload builder needs zero translation).
Constant Summary collapse
- CUSTOM_SEGMENTS =
This constant is part of a private API. You should avoid using this constant if possible, as it may be removed or be changed in the future.
The
customSegmentswire key — byte-identical to JSSegmentsKeys.CUSTOM_SEGMENTS(+segments-keys.ts:14+). The visitor's matched custom-segment ids live under this key inStoreData["segments"]. "customSegments"- SEGMENTS_KEYS =
This constant is part of a private API. You should avoid using this constant if possible, as it may be removed or be changed in the future.
The full report-segment key set — byte-identical to JS
SegmentsKeys(+segments-keys.ts:7-15+). The report-segment filter is restricted to exactly these seven; +visitorType+/+customSegments+ are the JS wire keys that diverge from PHP's snake_case variants (FR30). The SINGLE source of the allowed set. %w[ country browser devices source campaign visitorType customSegments ].freeze
Instance Method Summary collapse
-
#initialize(data_manager:, data_store_manager:, account_resolver:, project_resolver:, rule_manager:, log_manager: nil) ⇒ SegmentsManager
constructor
private
A new instance of SegmentsManager.
-
#put_segments(visitor_id, segments) ⇒ void
private
Set default report-segments for a visitor (JS
setDefaultSegments->putSegments,context.ts:434-436/segments-manager.ts:78-85). -
#select_custom_segments(visitor_id, segment_keys, segment_rule = nil) ⇒ Hash, ...
private
Evaluate the named custom segments for a visitor and attach matching ids (JS
selectCustomSegments->setCustomSegments,segments-manager.ts:153-185).
Constructor Details
#initialize(data_manager:, data_store_manager:, account_resolver:, project_resolver:, rule_manager:, log_manager: nil) ⇒ SegmentsManager
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns a new instance of SegmentsManager.
72 73 74 75 76 77 78 79 80 |
# File 'lib/convert_sdk/segments_manager.rb', line 72 def initialize(data_manager:, data_store_manager:, account_resolver:, project_resolver:, rule_manager:, log_manager: nil) @data_manager = data_manager @data_store_manager = data_store_manager @account_resolver = account_resolver @project_resolver = project_resolver @rule_manager = rule_manager @log_manager = log_manager end |
Instance Method Details
#put_segments(visitor_id, segments) ⇒ void
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
This method returns an undefined value.
Set default report-segments for a visitor (JS setDefaultSegments ->
putSegments, context.ts:434-436 / segments-manager.ts:78-85).
The supplied segments are passed through #filter_report_segments (only the
seven SEGMENTS_KEYS survive); a non-empty result is merged into the
visitor's StoreData["segments"] via the atomic store merge. An all-dropped
input is a no-op (JS if (reportSegments)).
93 94 95 96 97 98 99 |
# File 'lib/convert_sdk/segments_manager.rb', line 93 def put_segments(visitor_id, segments) report_segments = filter_report_segments(segments) return if report_segments.empty? merge_segments(visitor_id, report_segments) nil end |
#select_custom_segments(visitor_id, segment_keys, segment_rule = nil) ⇒ Hash, ...
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Evaluate the named custom segments for a visitor and attach matching ids
(JS selectCustomSegments -> setCustomSegments, segments-manager.ts:153-185).
Each requested key is resolved to a ConfigSegment via the DataManager
segments reader; the segment's rules are walked against segment_rule
by RuleManager#is_rule_matched. A surfaced RuleError sentinel propagates
out verbatim (no attachment). Matching segment ids are appended to the
visitor's stored customSegments list (deduped); an unknown key is skipped
with a debug log.
118 119 120 121 |
# File 'lib/convert_sdk/segments_manager.rb', line 118 def select_custom_segments(visitor_id, segment_keys, segment_rule = nil) segments = lookup_segments(segment_keys) set_custom_segments(visitor_id, segments, segment_rule) end |