Navegador

1
2
<!doctype html>
3
<html lang="en" class="no-js">
4
<head>
5
6
<meta charset="utf-8">
7
<meta name="viewport" content="width=device-width,initial-scale=1">
8
9
<meta name="description" content="Project knowledge graph for AI coding agents — code structure, business rules, and architectural decisions in one queryable graph">
10
11
12
<meta name="author" content="CONFLICT LLC">
13
14
15
<link rel="canonical" href="https://navegador.dev/guide/framework-enrichment/">
16
17
18
<link rel="prev" href="../context-loading/">
19
20
21
<link rel="next" href="../analysis/">
22
23
24
25
26
27
<link rel="icon" href="../../assets/images/favicon.png">
28
<meta name="generator" content="mkdocs-1.6.1, mkdocs-material-9.7.6">
29
30
31
32
<title>Framework Enrichment - Navegador</title>
33
34
35
36
<link rel="stylesheet" href="../../assets/stylesheets/main.484c7ddc.min.css">
37
38
39
<link rel="stylesheet" href="../../assets/stylesheets/palette.ab4e12ef.min.css">
40
41
42
43
44
45
46
47
48
49
50
51
52
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
53
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,300i,400,400i,700,700i%7CRoboto+Mono:400,400i,700,700i&display=fallback">
54
<style>:root{--md-text-font:"Roboto";--md-code-font:"Roboto Mono"}</style>
55
56
57
58
<link rel="stylesheet" href="../../assets/_mkdocstrings.css">
59
60
<link rel="stylesheet" href="../../assets/css/custom.css">
61
62
<script>__md_scope=new URL("../..",location),__md_hash=e=>[...e].reduce(((e,_)=>(e<<5)-e+_.charCodeAt(0)),0),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script>
63
64
65
66
67
68
</head>
69
70
71
72
73
74
75
76
77
78
<body dir="ltr" data-md-color-scheme="slate" data-md-color-primary="custom" data-md-color-accent="custom">
79
80
81
<input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
82
<input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
83
<label class="md-overlay" for="__drawer"></label>
84
<div data-md-component="skip">
85
86
87
<a href="#framework-enrichment" class="md-skip">
88
Skip to content
89
</a>
90
91
</div>
92
<div data-md-component="announce">
93
94
</div>
95
96
97
98
99
<header class="md-header" data-md-component="header">
100
<nav class="md-header__inner md-grid" aria-label="Header">
101
<a href="../.." title="Navegador" class="md-header__button md-logo" aria-label="Navegador" data-md-component="logo">
102
103
<img src="../../assets/images/conflict-logo.svg" alt="logo">
104
105
</a>
106
<label class="md-header__button md-icon" for="__drawer">
107
108
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3zm0 5h18v2H3zm0 5h18v2H3z"/></svg>
109
</label>
110
<div class="md-header__title" data-md-component="header-title">
111
<div class="md-header__ellipsis">
112
<div class="md-header__topic">
113
<span class="md-ellipsis">
114
Navegador
115
</span>
116
</div>
117
<div class="md-header__topic" data-md-component="header-topic">
118
<span class="md-ellipsis">
119
120
Framework Enrichment
121
122
</span>
123
</div>
124
</div>
125
</div>
126
127
128
<form class="md-header__option" data-md-component="palette">
129
130
131
132
133
<input class="md-option" data-md-color-media="(prefers-color-scheme: dark)" data-md-color-scheme="slate" data-md-color-primary="custom" data-md-color-accent="custom" aria-label="Switch to light mode" type="radio" name="__palette" id="__palette_0">
134
135
<label class="md-header__button md-icon" title="Switch to light mode" for="__palette_1" hidden>
136
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 18c-.89 0-1.74-.2-2.5-.55C11.56 16.5 13 14.42 13 12s-1.44-4.5-3.5-5.45C10.26 6.2 11.11 6 12 6a6 6 0 0 1 6 6 6 6 0 0 1-6 6m8-9.31V4h-4.69L12 .69 8.69 4H4v4.69L.69 12 4 15.31V20h4.69L12 23.31 15.31 20H20v-4.69L23.31 12z"/></svg>
137
</label>
138
139
140
141
142
143
<input class="md-option" data-md-color-media="(prefers-color-scheme: light)" data-md-color-scheme="default" data-md-color-primary="custom" data-md-color-accent="custom" aria-label="Switch to dark mode" type="radio" name="__palette" id="__palette_1">
144
145
<label class="md-header__button md-icon" title="Switch to dark mode" for="__palette_0" hidden>
146
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a4 4 0 0 0-4 4 4 4 0 0 0 4 4 4 4 0 0 0 4-4 4 4 0 0 0-4-4m0 10a6 6 0 0 1-6-6 6 6 0 0 1 6-6 6 6 0 0 1 6 6 6 6 0 0 1-6 6m8-9.31V4h-4.69L12 .69 8.69 4H4v4.69L.69 12 4 15.31V20h4.69L12 23.31 15.31 20H20v-4.69L23.31 12z"/></svg>
147
</label>
148
149
150
</form>
151
152
153
154
<script>var palette=__md_get("__palette");if(palette&&palette.color){if("(prefers-color-scheme)"===palette.color.media){var media=matchMedia("(prefers-color-scheme: light)"),input=document.querySelector(media.matches?"[data-md-color-media='(prefers-color-scheme: light)']":"[data-md-color-media='(prefers-color-scheme: dark)']");palette.color.media=input.getAttribute("data-md-color-media"),palette.color.scheme=input.getAttribute("data-md-color-scheme"),palette.color.primary=input.getAttribute("data-md-color-primary"),palette.color.accent=input.getAttribute("data-md-color-accent")}for(var[key,value]of Object.entries(palette.color))document.body.setAttribute("data-md-color-"+key,value)}</script>
155
156
157
158
159
160
<label class="md-header__button md-icon" for="__search">
161
162
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
163
</label>
164
<div class="md-search" data-md-component="search" role="dialog">
165
<label class="md-search__overlay" for="__search"></label>
166
<div class="md-search__inner" role="search">
167
<form class="md-search__form" name="search">
168
<input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" required>
169
<label class="md-search__icon md-icon" for="__search">
170
171
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
172
173
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11z"/></svg>
174
</label>
175
<nav class="md-search__options" aria-label="Search">
176
177
<button type="reset" class="md-search__icon md-icon" title="Clear" aria-label="Clear" tabindex="-1">
178
179
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>
180
</button>
181
</nav>
182
183
<div class="md-search__suggest" data-md-component="search-suggest"></div>
184
185
</form>
186
<div class="md-search__output">
187
<div class="md-search__scrollwrap" tabindex="0" data-md-scrollfix>
188
<div class="md-search-result" data-md-component="search-result">
189
<div class="md-search-result__meta">
190
Initializing search
191
</div>
192
<ol class="md-search-result__list" role="presentation"></ol>
193
</div>
194
</div>
195
</div>
196
</div>
197
</div>
198
199
200
201
<div class="md-header__source">
202
<a href="https://github.com/ConflictHQ/navegador" title="Go to repository" class="md-source" data-md-component="source">
203
<div class="md-source__icon md-icon">
204
205
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M173.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6m-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3m44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9M252.8 8C114.1 8 8 113.3 8 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C436.2 457.8 504 362.9 504 252 504 113.3 391.5 8 252.8 8M105.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1m-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7m32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1m-11.4-14.7c-1.6 1-1.6 3.6 0 5.9s4.3 3.3 5.6 2.3c1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2"/></svg>
206
</div>
207
<div class="md-source__repository">
208
ConflictHQ/navegador
209
</div>
210
</a>
211
</div>
212
213
</nav>
214
215
</header>
216
217
<div class="md-container" data-md-component="container">
218
219
220
221
222
223
<nav class="md-tabs" aria-label="Tabs" data-md-component="tabs">
224
<div class="md-grid">
225
<ul class="md-tabs__list">
226
227
228
229
230
231
232
<li class="md-tabs__item">
233
<a href="../.." class="md-tabs__link">
234
235
236
237
238
239
Home
240
241
</a>
242
</li>
243
244
245
246
247
248
249
250
251
252
253
<li class="md-tabs__item">
254
<a href="../../getting-started/installation/" class="md-tabs__link">
255
256
257
258
Getting Started
259
260
</a>
261
</li>
262
263
264
265
266
267
268
269
270
271
272
273
274
275
<li class="md-tabs__item md-tabs__item--active">
276
<a href="../ingestion/" class="md-tabs__link">
277
278
279
280
Guide
281
282
</a>
283
</li>
284
285
286
287
288
289
290
291
292
293
294
295
<li class="md-tabs__item">
296
<a href="../../architecture/overview/" class="md-tabs__link">
297
298
299
300
Architecture
301
302
</a>
303
</li>
304
305
306
307
308
309
310
311
312
313
314
315
<li class="md-tabs__item">
316
<a href="../../api/sdk/" class="md-tabs__link">
317
318
319
320
API Reference
321
322
</a>
323
</li>
324
325
326
327
328
</ul>
329
</div>
330
</nav>
331
332
333
334
<main class="md-main" data-md-component="main">
335
<div class="md-main__inner md-grid">
336
337
338
339
<div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
340
<div class="md-sidebar__scrollwrap">
341
<div class="md-sidebar__inner">
342
343
344
345
346
347
348
<nav class="md-nav md-nav--primary md-nav--lifted" aria-label="Navigation" data-md-level="0">
349
<label class="md-nav__title" for="__drawer">
350
<a href="../.." title="Navegador" class="md-nav__button md-logo" aria-label="Navegador" data-md-component="logo">
351
352
<img src="../../assets/images/conflict-logo.svg" alt="logo">
353
354
</a>
355
Navegador
356
</label>
357
358
<div class="md-nav__source">
359
<a href="https://github.com/ConflictHQ/navegador" title="Go to repository" class="md-source" data-md-component="source">
360
<div class="md-source__icon md-icon">
361
362
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M173.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6m-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3m44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9M252.8 8C114.1 8 8 113.3 8 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C436.2 457.8 504 362.9 504 252 504 113.3 391.5 8 252.8 8M105.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1m-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7m32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1m-11.4-14.7c-1.6 1-1.6 3.6 0 5.9s4.3 3.3 5.6 2.3c1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2"/></svg>
363
</div>
364
<div class="md-source__repository">
365
ConflictHQ/navegador
366
</div>
367
</a>
368
</div>
369
370
<ul class="md-nav__list" data-md-scrollfix>
371
372
373
374
375
376
377
378
<li class="md-nav__item">
379
<a href="../.." class="md-nav__link">
380
381
382
383
<span class="md-ellipsis">
384
385
386
Home
387
388
389
390
</span>
391
392
393
394
</a>
395
</li>
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
<li class="md-nav__item md-nav__item--nested">
416
417
418
419
420
421
<input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_2" >
422
423
424
<label class="md-nav__link" for="__nav_2" id="__nav_2_label" tabindex="0">
425
426
427
428
<span class="md-ellipsis">
429
430
431
Getting Started
432
433
434
435
</span>
436
437
438
439
<span class="md-nav__icon md-icon"></span>
440
</label>
441
442
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_2_label" aria-expanded="false">
443
<label class="md-nav__title" for="__nav_2">
444
<span class="md-nav__icon md-icon"></span>
445
446
447
Getting Started
448
449
450
</label>
451
<ul class="md-nav__list" data-md-scrollfix>
452
453
454
455
456
457
458
459
<li class="md-nav__item">
460
<a href="../../getting-started/installation/" class="md-nav__link">
461
462
463
464
<span class="md-ellipsis">
465
466
467
Installation
468
469
470
471
</span>
472
473
474
475
</a>
476
</li>
477
478
479
480
481
482
483
484
485
486
487
<li class="md-nav__item">
488
<a href="../../getting-started/quickstart/" class="md-nav__link">
489
490
491
492
<span class="md-ellipsis">
493
494
495
Quick Start
496
497
498
499
</span>
500
501
502
503
</a>
504
</li>
505
506
507
508
509
510
511
512
513
514
515
<li class="md-nav__item">
516
<a href="../../getting-started/configuration/" class="md-nav__link">
517
518
519
520
<span class="md-ellipsis">
521
522
523
Configuration
524
525
526
527
</span>
528
529
530
531
</a>
532
</li>
533
534
535
536
537
</ul>
538
</nav>
539
540
</li>
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
<li class="md-nav__item md-nav__item--active md-nav__item--section md-nav__item--nested">
566
567
568
569
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_3" checked>
570
571
572
<label class="md-nav__link" for="__nav_3" id="__nav_3_label" tabindex="">
573
574
575
576
<span class="md-ellipsis">
577
578
579
Guide
580
581
582
583
</span>
584
585
586
587
<span class="md-nav__icon md-icon"></span>
588
</label>
589
590
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_3_label" aria-expanded="true">
591
<label class="md-nav__title" for="__nav_3">
592
<span class="md-nav__icon md-icon"></span>
593
594
595
Guide
596
597
598
</label>
599
<ul class="md-nav__list" data-md-scrollfix>
600
601
602
603
604
605
606
607
<li class="md-nav__item">
608
<a href="../ingestion/" class="md-nav__link">
609
610
611
612
<span class="md-ellipsis">
613
614
615
Ingesting a Repo
616
617
618
619
</span>
620
621
622
623
</a>
624
</li>
625
626
627
628
629
630
631
632
633
634
635
<li class="md-nav__item">
636
<a href="../context-loading/" class="md-nav__link">
637
638
639
640
<span class="md-ellipsis">
641
642
643
Loading Context
644
645
646
647
</span>
648
649
650
651
</a>
652
</li>
653
654
655
656
657
658
659
660
661
662
663
664
665
<li class="md-nav__item md-nav__item--active">
666
667
<input class="md-nav__toggle md-toggle" type="checkbox" id="__toc">
668
669
670
671
672
673
<label class="md-nav__link md-nav__link--active" for="__toc">
674
675
676
677
<span class="md-ellipsis">
678
679
680
Framework Enrichment
681
682
683
684
</span>
685
686
687
688
<span class="md-nav__icon md-icon"></span>
689
</label>
690
691
<a href="./" class="md-nav__link md-nav__link--active">
692
693
694
695
<span class="md-ellipsis">
696
697
698
Framework Enrichment
699
700
701
702
</span>
703
704
705
706
</a>
707
708
709
710
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
711
712
713
714
715
716
717
<label class="md-nav__title" for="__toc">
718
<span class="md-nav__icon md-icon"></span>
719
Table of contents
720
</label>
721
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
722
723
<li class="md-nav__item">
724
<a href="#what-enrichment-does" class="md-nav__link">
725
<span class="md-ellipsis">
726
727
What enrichment does
728
729
</span>
730
</a>
731
732
</li>
733
734
<li class="md-nav__item">
735
<a href="#how-it-works" class="md-nav__link">
736
<span class="md-ellipsis">
737
738
How it works
739
740
</span>
741
</a>
742
743
</li>
744
745
<li class="md-nav__item">
746
<a href="#supported-frameworks" class="md-nav__link">
747
<span class="md-ellipsis">
748
749
Supported frameworks
750
751
</span>
752
</a>
753
754
</li>
755
756
<li class="md-nav__item">
757
<a href="#usage" class="md-nav__link">
758
<span class="md-ellipsis">
759
760
Usage
761
762
</span>
763
</a>
764
765
<nav class="md-nav" aria-label="Usage">
766
<ul class="md-nav__list">
767
768
<li class="md-nav__item">
769
<a href="#auto-detect-and-enrich-all-frameworks" class="md-nav__link">
770
<span class="md-ellipsis">
771
772
Auto-detect and enrich all frameworks
773
774
</span>
775
</a>
776
777
</li>
778
779
<li class="md-nav__item">
780
<a href="#enrich-immediately-after-ingestion" class="md-nav__link">
781
<span class="md-ellipsis">
782
783
Enrich immediately after ingestion
784
785
</span>
786
</a>
787
788
</li>
789
790
<li class="md-nav__item">
791
<a href="#target-a-specific-framework" class="md-nav__link">
792
<span class="md-ellipsis">
793
794
Target a specific framework
795
796
</span>
797
</a>
798
799
</li>
800
801
<li class="md-nav__item">
802
<a href="#json-output" class="md-nav__link">
803
<span class="md-ellipsis">
804
805
JSON output
806
807
</span>
808
</a>
809
810
</li>
811
812
</ul>
813
</nav>
814
815
</li>
816
817
<li class="md-nav__item">
818
<a href="#querying-enriched-nodes" class="md-nav__link">
819
<span class="md-ellipsis">
820
821
Querying enriched nodes
822
823
</span>
824
</a>
825
826
</li>
827
828
<li class="md-nav__item">
829
<a href="#adding-custom-enrichers" class="md-nav__link">
830
<span class="md-ellipsis">
831
832
Adding custom enrichers
833
834
</span>
835
</a>
836
837
<nav class="md-nav" aria-label="Adding custom enrichers">
838
<ul class="md-nav__list">
839
840
<li class="md-nav__item">
841
<a href="#1-create-the-enricher" class="md-nav__link">
842
<span class="md-ellipsis">
843
844
1. Create the enricher
845
846
</span>
847
</a>
848
849
</li>
850
851
<li class="md-nav__item">
852
<a href="#2-register-the-enricher" class="md-nav__link">
853
<span class="md-ellipsis">
854
855
2. Register the enricher
856
857
</span>
858
</a>
859
860
</li>
861
862
<li class="md-nav__item">
863
<a href="#3-load-at-startup" class="md-nav__link">
864
<span class="md-ellipsis">
865
866
3. Load at startup
867
868
</span>
869
</a>
870
871
</li>
872
873
</ul>
874
</nav>
875
876
</li>
877
878
</ul>
879
880
</nav>
881
882
</li>
883
884
885
886
887
888
889
890
891
892
893
<li class="md-nav__item">
894
<a href="../analysis/" class="md-nav__link">
895
896
897
898
<span class="md-ellipsis">
899
900
901
Structural Analysis
902
903
904
905
</span>
906
907
908
909
</a>
910
</li>
911
912
913
914
915
916
917
918
919
920
921
<li class="md-nav__item">
922
<a href="../intelligence/" class="md-nav__link">
923
924
925
926
<span class="md-ellipsis">
927
928
929
Intelligence Layer
930
931
932
933
</span>
934
935
936
937
</a>
938
</li>
939
940
941
942
943
944
945
946
947
948
949
<li class="md-nav__item">
950
<a href="../sdk/" class="md-nav__link">
951
952
953
954
<span class="md-ellipsis">
955
956
957
Python SDK
958
959
960
961
</span>
962
963
964
965
</a>
966
</li>
967
968
969
970
971
972
973
974
975
976
977
<li class="md-nav__item">
978
<a href="../graph-queries/" class="md-nav__link">
979
980
981
982
<span class="md-ellipsis">
983
984
985
Graph Queries
986
987
988
989
</span>
990
991
992
993
</a>
994
</li>
995
996
997
998
999
1000
1001
1002
1003
1004
1005
<li class="md-nav__item">
1006
<a href="../mcp-integration/" class="md-nav__link">
1007
1008
1009
1010
<span class="md-ellipsis">
1011
1012
1013
MCP Integration
1014
1015
1016
1017
</span>
1018
1019
1020
1021
</a>
1022
</li>
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
<li class="md-nav__item">
1034
<a href="../ci-cd/" class="md-nav__link">
1035
1036
1037
1038
<span class="md-ellipsis">
1039
1040
1041
CI/CD
1042
1043
1044
1045
</span>
1046
1047
1048
1049
</a>
1050
</li>
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
<li class="md-nav__item">
1062
<a href="../cluster/" class="md-nav__link">
1063
1064
1065
1066
<span class="md-ellipsis">
1067
1068
1069
Cluster Mode
1070
1071
1072
1073
</span>
1074
1075
1076
1077
</a>
1078
</li>
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
<li class="md-nav__item">
1090
<a href="../agent-hooks/" class="md-nav__link">
1091
1092
1093
1094
<span class="md-ellipsis">
1095
1096
1097
Agent Hooks
1098
1099
1100
1101
</span>
1102
1103
1104
1105
</a>
1106
</li>
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
<li class="md-nav__item">
1118
<a href="../planopticon/" class="md-nav__link">
1119
1120
1121
1122
<span class="md-ellipsis">
1123
1124
1125
Planopticon
1126
1127
1128
1129
</span>
1130
1131
1132
1133
</a>
1134
</li>
1135
1136
1137
1138
1139
</ul>
1140
</nav>
1141
1142
</li>
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
<li class="md-nav__item md-nav__item--nested">
1163
1164
1165
1166
1167
1168
<input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_4" >
1169
1170
1171
<label class="md-nav__link" for="__nav_4" id="__nav_4_label" tabindex="0">
1172
1173
1174
1175
<span class="md-ellipsis">
1176
1177
1178
Architecture
1179
1180
1181
1182
</span>
1183
1184
1185
1186
<span class="md-nav__icon md-icon"></span>
1187
</label>
1188
1189
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_4_label" aria-expanded="false">
1190
<label class="md-nav__title" for="__nav_4">
1191
<span class="md-nav__icon md-icon"></span>
1192
1193
1194
Architecture
1195
1196
1197
</label>
1198
<ul class="md-nav__list" data-md-scrollfix>
1199
1200
1201
1202
1203
1204
1205
1206
<li class="md-nav__item">
1207
<a href="../../architecture/overview/" class="md-nav__link">
1208
1209
1210
1211
<span class="md-ellipsis">
1212
1213
1214
Overview
1215
1216
1217
1218
</span>
1219
1220
1221
1222
</a>
1223
</li>
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
<li class="md-nav__item">
1235
<a href="../../architecture/graph-schema/" class="md-nav__link">
1236
1237
1238
1239
<span class="md-ellipsis">
1240
1241
1242
Graph Schema
1243
1244
1245
1246
</span>
1247
1248
1249
1250
</a>
1251
</li>
1252
1253
1254
1255
1256
</ul>
1257
</nav>
1258
1259
</li>
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
<li class="md-nav__item md-nav__item--nested">
1280
1281
1282
1283
1284
1285
<input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_5" >
1286
1287
1288
<label class="md-nav__link" for="__nav_5" id="__nav_5_label" tabindex="0">
1289
1290
1291
1292
<span class="md-ellipsis">
1293
1294
1295
API Reference
1296
1297
1298
1299
</span>
1300
1301
1302
1303
<span class="md-nav__icon md-icon"></span>
1304
</label>
1305
1306
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_5_label" aria-expanded="false">
1307
<label class="md-nav__title" for="__nav_5">
1308
<span class="md-nav__icon md-icon"></span>
1309
1310
1311
API Reference
1312
1313
1314
</label>
1315
<ul class="md-nav__list" data-md-scrollfix>
1316
1317
1318
1319
1320
1321
1322
1323
<li class="md-nav__item">
1324
<a href="../../api/sdk/" class="md-nav__link">
1325
1326
1327
1328
<span class="md-ellipsis">
1329
1330
1331
Python SDK
1332
1333
1334
1335
</span>
1336
1337
1338
1339
</a>
1340
</li>
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
<li class="md-nav__item">
1352
<a href="../../api/ingestion/" class="md-nav__link">
1353
1354
1355
1356
<span class="md-ellipsis">
1357
1358
1359
Ingestion
1360
1361
1362
1363
</span>
1364
1365
1366
1367
</a>
1368
</li>
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
<li class="md-nav__item">
1380
<a href="../../api/analysis/" class="md-nav__link">
1381
1382
1383
1384
<span class="md-ellipsis">
1385
1386
1387
Analysis
1388
1389
1390
1391
</span>
1392
1393
1394
1395
</a>
1396
</li>
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
<li class="md-nav__item">
1408
<a href="../../api/graph/" class="md-nav__link">
1409
1410
1411
1412
<span class="md-ellipsis">
1413
1414
1415
Graph
1416
1417
1418
1419
</span>
1420
1421
1422
1423
</a>
1424
</li>
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
<li class="md-nav__item">
1436
<a href="../../api/mcp/" class="md-nav__link">
1437
1438
1439
1440
<span class="md-ellipsis">
1441
1442
1443
MCP Server
1444
1445
1446
1447
</span>
1448
1449
1450
1451
</a>
1452
</li>
1453
1454
1455
1456
1457
</ul>
1458
</nav>
1459
1460
</li>
1461
1462
1463
1464
</ul>
1465
</nav>
1466
</div>
1467
</div>
1468
</div>
1469
1470
1471
1472
<div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
1473
<div class="md-sidebar__scrollwrap">
1474
<div class="md-sidebar__inner">
1475
1476
1477
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
1478
1479
1480
1481
1482
1483
1484
<label class="md-nav__title" for="__toc">
1485
<span class="md-nav__icon md-icon"></span>
1486
Table of contents
1487
</label>
1488
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
1489
1490
<li class="md-nav__item">
1491
<a href="#what-enrichment-does" class="md-nav__link">
1492
<span class="md-ellipsis">
1493
1494
What enrichment does
1495
1496
</span>
1497
</a>
1498
1499
</li>
1500
1501
<li class="md-nav__item">
1502
<a href="#how-it-works" class="md-nav__link">
1503
<span class="md-ellipsis">
1504
1505
How it works
1506
1507
</span>
1508
</a>
1509
1510
</li>
1511
1512
<li class="md-nav__item">
1513
<a href="#supported-frameworks" class="md-nav__link">
1514
<span class="md-ellipsis">
1515
1516
Supported frameworks
1517
1518
</span>
1519
</a>
1520
1521
</li>
1522
1523
<li class="md-nav__item">
1524
<a href="#usage" class="md-nav__link">
1525
<span class="md-ellipsis">
1526
1527
Usage
1528
1529
</span>
1530
</a>
1531
1532
<nav class="md-nav" aria-label="Usage">
1533
<ul class="md-nav__list">
1534
1535
<li class="md-nav__item">
1536
<a href="#auto-detect-and-enrich-all-frameworks" class="md-nav__link">
1537
<span class="md-ellipsis">
1538
1539
Auto-detect and enrich all frameworks
1540
1541
</span>
1542
</a>
1543
1544
</li>
1545
1546
<li class="md-nav__item">
1547
<a href="#enrich-immediately-after-ingestion" class="md-nav__link">
1548
<span class="md-ellipsis">
1549
1550
Enrich immediately after ingestion
1551
1552
</span>
1553
</a>
1554
1555
</li>
1556
1557
<li class="md-nav__item">
1558
<a href="#target-a-specific-framework" class="md-nav__link">
1559
<span class="md-ellipsis">
1560
1561
Target a specific framework
1562
1563
</span>
1564
</a>
1565
1566
</li>
1567
1568
<li class="md-nav__item">
1569
<a href="#json-output" class="md-nav__link">
1570
<span class="md-ellipsis">
1571
1572
JSON output
1573
1574
</span>
1575
</a>
1576
1577
</li>
1578
1579
</ul>
1580
</nav>
1581
1582
</li>
1583
1584
<li class="md-nav__item">
1585
<a href="#querying-enriched-nodes" class="md-nav__link">
1586
<span class="md-ellipsis">
1587
1588
Querying enriched nodes
1589
1590
</span>
1591
</a>
1592
1593
</li>
1594
1595
<li class="md-nav__item">
1596
<a href="#adding-custom-enrichers" class="md-nav__link">
1597
<span class="md-ellipsis">
1598
1599
Adding custom enrichers
1600
1601
</span>
1602
</a>
1603
1604
<nav class="md-nav" aria-label="Adding custom enrichers">
1605
<ul class="md-nav__list">
1606
1607
<li class="md-nav__item">
1608
<a href="#1-create-the-enricher" class="md-nav__link">
1609
<span class="md-ellipsis">
1610
1611
1. Create the enricher
1612
1613
</span>
1614
</a>
1615
1616
</li>
1617
1618
<li class="md-nav__item">
1619
<a href="#2-register-the-enricher" class="md-nav__link">
1620
<span class="md-ellipsis">
1621
1622
2. Register the enricher
1623
1624
</span>
1625
</a>
1626
1627
</li>
1628
1629
<li class="md-nav__item">
1630
<a href="#3-load-at-startup" class="md-nav__link">
1631
<span class="md-ellipsis">
1632
1633
3. Load at startup
1634
1635
</span>
1636
</a>
1637
1638
</li>
1639
1640
</ul>
1641
</nav>
1642
1643
</li>
1644
1645
</ul>
1646
1647
</nav>
1648
</div>
1649
</div>
1650
</div>
1651
1652
1653
1654
<div class="md-content" data-md-component="content">
1655
1656
<article class="md-content__inner md-typeset">
1657
1658
1659
1660
1661
1662
1663
1664
1665
<h1 id="framework-enrichment">Framework Enrichment<a class="headerlink" href="#framework-enrichment" title="Permanent link">&para;</a></h1>
1666
<h2 id="what-enrichment-does">What enrichment does<a class="headerlink" href="#what-enrichment-does" title="Permanent link">&para;</a></h2>
1667
<p>After ingestion, navegador's graph contains generic structural nodes: <code>Function</code>, <code>Class</code>, <code>File</code>, <code>Import</code>. Enrichment promotes those generic nodes to <strong>semantic types</strong> that reflect how the code is actually used.</p>
1668
<p>For example, a Django view function becomes a <code>View</code> node. A pytest function becomes a <code>Test</code> node. A Flask route decorator triggers creation of a <code>Route</code> node with the URL pattern extracted.</p>
1669
<p>This lets you ask questions that wouldn't be possible from structure alone:</p>
1670
<div class="highlight"><pre><span></span><code><a id="__codelineno-0-1" name="__codelineno-0-1" href="#__codelineno-0-1"></a><span class="c1"># without enrichment: grep for &quot;def test_&quot;</span>
1671
<a id="__codelineno-0-2" name="__codelineno-0-2" href="#__codelineno-0-2"></a><span class="c1"># with enrichment: query the graph by semantic type</span>
1672
<a id="__codelineno-0-3" name="__codelineno-0-3" href="#__codelineno-0-3"></a>navegador<span class="w"> </span>query<span class="w"> </span><span class="s2">&quot;MATCH (t:Test) RETURN t.name, t.file ORDER BY t.file&quot;</span>
1673
<a id="__codelineno-0-4" name="__codelineno-0-4" href="#__codelineno-0-4"></a>
1674
<a id="__codelineno-0-5" name="__codelineno-0-5" href="#__codelineno-0-5"></a><span class="c1"># find all API routes</span>
1675
<a id="__codelineno-0-6" name="__codelineno-0-6" href="#__codelineno-0-6"></a>navegador<span class="w"> </span>query<span class="w"> </span><span class="s2">&quot;MATCH (r:Route) RETURN r.method, r.path, r.handler ORDER BY r.path&quot;</span>
1676
</code></pre></div>
1677
<hr />
1678
<h2 id="how-it-works">How it works<a class="headerlink" href="#how-it-works" title="Permanent link">&para;</a></h2>
1679
<p>Enrichment runs as a post-ingest pass. It reads existing nodes and edges, applies framework-specific pattern matching (decorator names, base class names, naming conventions), and:</p>
1680
<ol>
1681
<li>Adds semantic labels to matched nodes (e.g., adds <code>View</code> label to Django view functions)</li>
1682
<li>Creates typed edges where the framework implies relationships (e.g., <code>HANDLES</code> from a <code>Route</code> to its handler function)</li>
1683
<li>Extracts framework-specific properties (e.g., HTTP method and URL pattern from route decorators)</li>
1684
</ol>
1685
<p>Enrichment is <strong>non-destructive</strong> — it never removes or modifies existing nodes, only adds labels and edges.</p>
1686
<hr />
1687
<h2 id="supported-frameworks">Supported frameworks<a class="headerlink" href="#supported-frameworks" title="Permanent link">&para;</a></h2>
1688
<table>
1689
<thead>
1690
<tr>
1691
<th>Framework</th>
1692
<th>Language</th>
1693
<th>Detected patterns</th>
1694
<th>Semantic types added</th>
1695
</tr>
1696
</thead>
1697
<tbody>
1698
<tr>
1699
<td>Django</td>
1700
<td>Python</td>
1701
<td><code>View</code> subclasses, <code>urlpatterns</code>, <code>@login_required</code></td>
1702
<td><code>View</code>, <code>Route</code>, <code>Model</code>, <code>Form</code>, <code>Middleware</code></td>
1703
</tr>
1704
<tr>
1705
<td>Flask</td>
1706
<td>Python</td>
1707
<td><code>@app.route</code>, <code>@blueprint.route</code>, <code>MethodView</code></td>
1708
<td><code>Route</code>, <code>View</code>, <code>Blueprint</code></td>
1709
</tr>
1710
<tr>
1711
<td>FastAPI</td>
1712
<td>Python</td>
1713
<td><code>@router.get/post/put/delete/patch</code>, <code>APIRouter</code></td>
1714
<td><code>Route</code>, <code>Schema</code>, <code>Dependency</code></td>
1715
</tr>
1716
<tr>
1717
<td>pytest</td>
1718
<td>Python</td>
1719
<td><code>def test_*</code>, <code>@pytest.mark.*</code>, <code>conftest.py</code></td>
1720
<td><code>Test</code>, <code>Fixture</code>, <code>TestSuite</code></td>
1721
</tr>
1722
<tr>
1723
<td>SQLAlchemy</td>
1724
<td>Python</td>
1725
<td><code>Base</code> subclasses, <code>Column</code>, <code>relationship()</code></td>
1726
<td><code>Model</code>, <code>Column</code>, <code>Relation</code></td>
1727
</tr>
1728
<tr>
1729
<td>Next.js</td>
1730
<td>TypeScript</td>
1731
<td><code>pages/</code>, <code>app/</code>, <code>getServerSideProps</code></td>
1732
<td><code>Page</code>, <code>Route</code>, <code>ServerComponent</code></td>
1733
</tr>
1734
<tr>
1735
<td>Express</td>
1736
<td>JavaScript</td>
1737
<td><code>app.get/post/put/delete</code>, <code>Router</code></td>
1738
<td><code>Route</code>, <code>Middleware</code></td>
1739
</tr>
1740
<tr>
1741
<td>NestJS</td>
1742
<td>TypeScript</td>
1743
<td><code>@Controller</code>, <code>@Injectable</code>, <code>@Module</code></td>
1744
<td><code>Controller</code>, <code>Service</code>, <code>Module</code></td>
1745
</tr>
1746
<tr>
1747
<td><strong>Terraform</strong></td>
1748
<td>HCL</td>
1749
<td><code>main.tf</code>, <code>variables.tf</code>, <code>outputs.tf</code></td>
1750
<td>Cross-file module resolution, provider grouping</td>
1751
</tr>
1752
<tr>
1753
<td><strong>Chef</strong></td>
1754
<td>Ruby</td>
1755
<td><code>metadata.rb</code>, <code>Berksfile</code></td>
1756
<td><code>chef_recipe</code>, <code>chef_resource</code>, <code>chef_cookbook</code>, <code>chef_include</code></td>
1757
</tr>
1758
</tbody>
1759
</table>
1760
<div class="admonition note">
1761
<p class="admonition-title">Note</p>
1762
<p>Framework detection is automatic when <code>--framework auto</code> is used (the default). Navegador inspects imports and decorator patterns to identify which frameworks are present.</p>
1763
</div>
1764
<hr />
1765
<h2 id="usage">Usage<a class="headerlink" href="#usage" title="Permanent link">&para;</a></h2>
1766
<h3 id="auto-detect-and-enrich-all-frameworks">Auto-detect and enrich all frameworks<a class="headerlink" href="#auto-detect-and-enrich-all-frameworks" title="Permanent link">&para;</a></h3>
1767
<div class="highlight"><pre><span></span><code><a id="__codelineno-1-1" name="__codelineno-1-1" href="#__codelineno-1-1"></a>navegador<span class="w"> </span>enrich<span class="w"> </span>./src
1768
</code></pre></div>
1769
<p>This runs after ingestion and enriches everything it can detect automatically.</p>
1770
<h3 id="enrich-immediately-after-ingestion">Enrich immediately after ingestion<a class="headerlink" href="#enrich-immediately-after-ingestion" title="Permanent link">&para;</a></h3>
1771
<div class="highlight"><pre><span></span><code><a id="__codelineno-2-1" name="__codelineno-2-1" href="#__codelineno-2-1"></a>navegador<span class="w"> </span>ingest<span class="w"> </span>./src<span class="w"> </span><span class="o">&amp;&amp;</span><span class="w"> </span>navegador<span class="w"> </span>enrich<span class="w"> </span>./src
1772
</code></pre></div>
1773
<p>Or use the <code>--enrich</code> flag on ingest:</p>
1774
<div class="highlight"><pre><span></span><code><a id="__codelineno-3-1" name="__codelineno-3-1" href="#__codelineno-3-1"></a>navegador<span class="w"> </span>ingest<span class="w"> </span>./src<span class="w"> </span>--enrich
1775
</code></pre></div>
1776
<h3 id="target-a-specific-framework">Target a specific framework<a class="headerlink" href="#target-a-specific-framework" title="Permanent link">&para;</a></h3>
1777
<div class="highlight"><pre><span></span><code><a id="__codelineno-4-1" name="__codelineno-4-1" href="#__codelineno-4-1"></a>navegador<span class="w"> </span>enrich<span class="w"> </span>./src<span class="w"> </span>--framework<span class="w"> </span>django
1778
<a id="__codelineno-4-2" name="__codelineno-4-2" href="#__codelineno-4-2"></a>navegador<span class="w"> </span>enrich<span class="w"> </span>./src<span class="w"> </span>--framework<span class="w"> </span>fastapi
1779
<a id="__codelineno-4-3" name="__codelineno-4-3" href="#__codelineno-4-3"></a>navegador<span class="w"> </span>enrich<span class="w"> </span>./src<span class="w"> </span>--framework<span class="w"> </span>pytest
1780
</code></pre></div>
1781
<p>Valid values: <code>django</code>, <code>flask</code>, <code>fastapi</code>, <code>pytest</code>, <code>sqlalchemy</code>, <code>nextjs</code>, <code>express</code>, <code>nestjs</code>, <code>terraform</code>, <code>chef</code>, <code>auto</code> (default).</p>
1782
<h3 id="json-output">JSON output<a class="headerlink" href="#json-output" title="Permanent link">&para;</a></h3>
1783
<div class="highlight"><pre><span></span><code><a id="__codelineno-5-1" name="__codelineno-5-1" href="#__codelineno-5-1"></a>navegador<span class="w"> </span>enrich<span class="w"> </span>./src<span class="w"> </span>--json
1784
</code></pre></div>
1785
<p>Returns a summary of labels and edges added per framework.</p>
1786
<hr />
1787
<h2 id="querying-enriched-nodes">Querying enriched nodes<a class="headerlink" href="#querying-enriched-nodes" title="Permanent link">&para;</a></h2>
1788
<p>Once enriched, the semantic types are queryable via Cypher:</p>
1789
<div class="highlight"><pre><span></span><code><a id="__codelineno-6-1" name="__codelineno-6-1" href="#__codelineno-6-1"></a><span class="c1"># all FastAPI routes with their HTTP methods</span>
1790
<a id="__codelineno-6-2" name="__codelineno-6-2" href="#__codelineno-6-2"></a>navegador<span class="w"> </span>query<span class="w"> </span><span class="s2">&quot;MATCH (r:Route) RETURN r.method, r.path, r.handler ORDER BY r.path&quot;</span>
1791
<a id="__codelineno-6-3" name="__codelineno-6-3" href="#__codelineno-6-3"></a>
1792
<a id="__codelineno-6-4" name="__codelineno-6-4" href="#__codelineno-6-4"></a><span class="c1"># all SQLAlchemy models and their columns</span>
1793
<a id="__codelineno-6-5" name="__codelineno-6-5" href="#__codelineno-6-5"></a>navegador<span class="w"> </span>query<span class="w"> </span><span class="s2">&quot;MATCH (m:Model)-[:HAS_COLUMN]-&gt;(c:Column) RETURN m.name, c.name, c.type ORDER BY m.name&quot;</span>
1794
<a id="__codelineno-6-6" name="__codelineno-6-6" href="#__codelineno-6-6"></a>
1795
<a id="__codelineno-6-7" name="__codelineno-6-7" href="#__codelineno-6-7"></a><span class="c1"># all pytest tests that reference a specific function</span>
1796
<a id="__codelineno-6-8" name="__codelineno-6-8" href="#__codelineno-6-8"></a>navegador<span class="w"> </span>query<span class="w"> </span><span class="s2">&quot;MATCH (t:Test)-[:CALLS]-&gt;(f:Function {name: &#39;process_payment&#39;}) RETURN t.name, t.file&quot;</span>
1797
<a id="__codelineno-6-9" name="__codelineno-6-9" href="#__codelineno-6-9"></a>
1798
<a id="__codelineno-6-10" name="__codelineno-6-10" href="#__codelineno-6-10"></a><span class="c1"># all Django views governed by a rule</span>
1799
<a id="__codelineno-6-11" name="__codelineno-6-11" href="#__codelineno-6-11"></a>navegador<span class="w"> </span>query<span class="w"> </span><span class="s2">&quot;MATCH (r:Rule)-[:GOVERNS]-&gt;(v:View) RETURN r.name, v.name, v.file&quot;</span>
1800
</code></pre></div>
1801
<hr />
1802
<h2 id="adding-custom-enrichers">Adding custom enrichers<a class="headerlink" href="#adding-custom-enrichers" title="Permanent link">&para;</a></h2>
1803
<p>Enrichers are subclasses of <code>FrameworkEnricher</code>. Create one to add support for an internal framework or library.</p>
1804
<h3 id="1-create-the-enricher">1. Create the enricher<a class="headerlink" href="#1-create-the-enricher" title="Permanent link">&para;</a></h3>
1805
<div class="highlight"><pre><span></span><code><a id="__codelineno-7-1" name="__codelineno-7-1" href="#__codelineno-7-1"></a><span class="c1"># myproject/enrichers/celery.py</span>
1806
<a id="__codelineno-7-2" name="__codelineno-7-2" href="#__codelineno-7-2"></a><span class="kn">from</span><span class="w"> </span><span class="nn">navegador.enrichment.base</span><span class="w"> </span><span class="kn">import</span> <span class="n">FrameworkEnricher</span><span class="p">,</span> <span class="n">EnrichmentResult</span>
1807
<a id="__codelineno-7-3" name="__codelineno-7-3" href="#__codelineno-7-3"></a><span class="kn">from</span><span class="w"> </span><span class="nn">navegador.graph</span><span class="w"> </span><span class="kn">import</span> <span class="n">GraphStore</span>
1808
<a id="__codelineno-7-4" name="__codelineno-7-4" href="#__codelineno-7-4"></a>
1809
<a id="__codelineno-7-5" name="__codelineno-7-5" href="#__codelineno-7-5"></a><span class="k">class</span><span class="w"> </span><span class="nc">CeleryEnricher</span><span class="p">(</span><span class="n">FrameworkEnricher</span><span class="p">):</span>
1810
<a id="__codelineno-7-6" name="__codelineno-7-6" href="#__codelineno-7-6"></a> <span class="n">name</span> <span class="o">=</span> <span class="s2">&quot;celery&quot;</span>
1811
<a id="__codelineno-7-7" name="__codelineno-7-7" href="#__codelineno-7-7"></a>
1812
<a id="__codelineno-7-8" name="__codelineno-7-8" href="#__codelineno-7-8"></a> <span class="k">def</span><span class="w"> </span><span class="nf">detect</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">store</span><span class="p">:</span> <span class="n">GraphStore</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="nb">bool</span><span class="p">:</span>
1813
<a id="__codelineno-7-9" name="__codelineno-7-9" href="#__codelineno-7-9"></a><span class="w"> </span><span class="sd">&quot;&quot;&quot;Return True if this framework is present in the graph.&quot;&quot;&quot;</span>
1814
<a id="__codelineno-7-10" name="__codelineno-7-10" href="#__codelineno-7-10"></a> <span class="n">results</span> <span class="o">=</span> <span class="n">store</span><span class="o">.</span><span class="n">query</span><span class="p">(</span>
1815
<a id="__codelineno-7-11" name="__codelineno-7-11" href="#__codelineno-7-11"></a> <span class="s2">&quot;MATCH (i:Import {name: &#39;celery&#39;}) RETURN count(i) AS n&quot;</span>
1816
<a id="__codelineno-7-12" name="__codelineno-7-12" href="#__codelineno-7-12"></a> <span class="p">)</span>
1817
<a id="__codelineno-7-13" name="__codelineno-7-13" href="#__codelineno-7-13"></a> <span class="k">return</span> <span class="n">results</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="s2">&quot;n&quot;</span><span class="p">]</span> <span class="o">&gt;</span> <span class="mi">0</span>
1818
<a id="__codelineno-7-14" name="__codelineno-7-14" href="#__codelineno-7-14"></a>
1819
<a id="__codelineno-7-15" name="__codelineno-7-15" href="#__codelineno-7-15"></a> <span class="k">def</span><span class="w"> </span><span class="nf">enrich</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">store</span><span class="p">:</span> <span class="n">GraphStore</span><span class="p">)</span> <span class="o">-&gt;</span> <span class="n">EnrichmentResult</span><span class="p">:</span>
1820
<a id="__codelineno-7-16" name="__codelineno-7-16" href="#__codelineno-7-16"></a><span class="w"> </span><span class="sd">&quot;&quot;&quot;Add semantic labels and edges for Celery tasks.&quot;&quot;&quot;</span>
1821
<a id="__codelineno-7-17" name="__codelineno-7-17" href="#__codelineno-7-17"></a> <span class="c1"># Find functions decorated with @shared_task or @app.task</span>
1822
<a id="__codelineno-7-18" name="__codelineno-7-18" href="#__codelineno-7-18"></a> <span class="n">tasks</span> <span class="o">=</span> <span class="n">store</span><span class="o">.</span><span class="n">query</span><span class="p">(</span>
1823
<a id="__codelineno-7-19" name="__codelineno-7-19" href="#__codelineno-7-19"></a> <span class="s2">&quot;MATCH (d:Decorator)-[:DECORATES]-&gt;(f:Function) &quot;</span>
1824
<a id="__codelineno-7-20" name="__codelineno-7-20" href="#__codelineno-7-20"></a> <span class="s2">&quot;WHERE d.name IN [&#39;shared_task&#39;, &#39;task&#39;] &quot;</span>
1825
<a id="__codelineno-7-21" name="__codelineno-7-21" href="#__codelineno-7-21"></a> <span class="s2">&quot;RETURN f.id, f.name&quot;</span>
1826
<a id="__codelineno-7-22" name="__codelineno-7-22" href="#__codelineno-7-22"></a> <span class="p">)</span>
1827
<a id="__codelineno-7-23" name="__codelineno-7-23" href="#__codelineno-7-23"></a> <span class="n">labels_added</span> <span class="o">=</span> <span class="mi">0</span>
1828
<a id="__codelineno-7-24" name="__codelineno-7-24" href="#__codelineno-7-24"></a> <span class="k">for</span> <span class="n">row</span> <span class="ow">in</span> <span class="n">tasks</span><span class="p">:</span>
1829
<a id="__codelineno-7-25" name="__codelineno-7-25" href="#__codelineno-7-25"></a> <span class="n">store</span><span class="o">.</span><span class="n">query</span><span class="p">(</span>
1830
<a id="__codelineno-7-26" name="__codelineno-7-26" href="#__codelineno-7-26"></a> <span class="s2">&quot;MATCH (f:Function) WHERE id(f) = $id &quot;</span>
1831
<a id="__codelineno-7-27" name="__codelineno-7-27" href="#__codelineno-7-27"></a> <span class="s2">&quot;SET f:Task&quot;</span><span class="p">,</span>
1832
<a id="__codelineno-7-28" name="__codelineno-7-28" href="#__codelineno-7-28"></a> <span class="n">params</span><span class="o">=</span><span class="p">{</span><span class="s2">&quot;id&quot;</span><span class="p">:</span> <span class="n">row</span><span class="p">[</span><span class="s2">&quot;f.id&quot;</span><span class="p">]}</span>
1833
<a id="__codelineno-7-29" name="__codelineno-7-29" href="#__codelineno-7-29"></a> <span class="p">)</span>
1834
<a id="__codelineno-7-30" name="__codelineno-7-30" href="#__codelineno-7-30"></a> <span class="n">labels_added</span> <span class="o">+=</span> <span class="mi">1</span>
1835
<a id="__codelineno-7-31" name="__codelineno-7-31" href="#__codelineno-7-31"></a>
1836
<a id="__codelineno-7-32" name="__codelineno-7-32" href="#__codelineno-7-32"></a> <span class="k">return</span> <span class="n">EnrichmentResult</span><span class="p">(</span><span class="n">labels_added</span><span class="o">=</span><span class="n">labels_added</span><span class="p">,</span> <span class="n">edges_added</span><span class="o">=</span><span class="mi">0</span><span class="p">)</span>
1837
</code></pre></div>
1838
<h3 id="2-register-the-enricher">2. Register the enricher<a class="headerlink" href="#2-register-the-enricher" title="Permanent link">&para;</a></h3>
1839
<div class="highlight"><pre><span></span><code><a id="__codelineno-8-1" name="__codelineno-8-1" href="#__codelineno-8-1"></a><span class="c1"># myproject/enrichers/__init__.py</span>
1840
<a id="__codelineno-8-2" name="__codelineno-8-2" href="#__codelineno-8-2"></a><span class="kn">from</span><span class="w"> </span><span class="nn">navegador.enrichment.registry</span><span class="w"> </span><span class="kn">import</span> <span class="n">register_enricher</span>
1841
<a id="__codelineno-8-3" name="__codelineno-8-3" href="#__codelineno-8-3"></a><span class="kn">from</span><span class="w"> </span><span class="nn">.celery</span><span class="w"> </span><span class="kn">import</span> <span class="n">CeleryEnricher</span>
1842
<a id="__codelineno-8-4" name="__codelineno-8-4" href="#__codelineno-8-4"></a>
1843
<a id="__codelineno-8-5" name="__codelineno-8-5" href="#__codelineno-8-5"></a><span class="n">register_enricher</span><span class="p">(</span><span class="n">CeleryEnricher</span><span class="p">())</span>
1844
</code></pre></div>
1845
<h3 id="3-load-at-startup">3. Load at startup<a class="headerlink" href="#3-load-at-startup" title="Permanent link">&para;</a></h3>
1846
<p>Import the registration module before running enrichment. In a CLI wrapper or agent hook:</p>
1847
<div class="highlight"><pre><span></span><code><a id="__codelineno-9-1" name="__codelineno-9-1" href="#__codelineno-9-1"></a><span class="kn">import</span><span class="w"> </span><span class="nn">myproject.enrichers</span> <span class="c1"># registers the enricher</span>
1848
<a id="__codelineno-9-2" name="__codelineno-9-2" href="#__codelineno-9-2"></a><span class="kn">from</span><span class="w"> </span><span class="nn">navegador.enrichment</span><span class="w"> </span><span class="kn">import</span> <span class="n">run_enrichment</span>
1849
<a id="__codelineno-9-3" name="__codelineno-9-3" href="#__codelineno-9-3"></a><span class="kn">from</span><span class="w"> </span><span class="nn">navegador.graph</span><span class="w"> </span><span class="kn">import</span> <span class="n">GraphStore</span>
1850
<a id="__codelineno-9-4" name="__codelineno-9-4" href="#__codelineno-9-4"></a>
1851
<a id="__codelineno-9-5" name="__codelineno-9-5" href="#__codelineno-9-5"></a><span class="n">store</span> <span class="o">=</span> <span class="n">GraphStore</span><span class="o">.</span><span class="n">sqlite</span><span class="p">(</span><span class="s2">&quot;.navegador/navegador.db&quot;</span><span class="p">)</span>
1852
<a id="__codelineno-9-6" name="__codelineno-9-6" href="#__codelineno-9-6"></a><span class="n">result</span> <span class="o">=</span> <span class="n">run_enrichment</span><span class="p">(</span><span class="n">store</span><span class="p">,</span> <span class="n">framework</span><span class="o">=</span><span class="s2">&quot;celery&quot;</span><span class="p">)</span>
1853
<a id="__codelineno-9-7" name="__codelineno-9-7" href="#__codelineno-9-7"></a><span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s2">&quot;Added </span><span class="si">{</span><span class="n">result</span><span class="o">.</span><span class="n">labels_added</span><span class="si">}</span><span class="s2"> labels&quot;</span><span class="p">)</span>
1854
</code></pre></div>
1855
<p>Or pass the module path to the CLI via <code>NAVEGADOR_ENRICHERS</code>:</p>
1856
<div class="highlight"><pre><span></span><code><a id="__codelineno-10-1" name="__codelineno-10-1" href="#__codelineno-10-1"></a><span class="nv">NAVEGADOR_ENRICHERS</span><span class="o">=</span>myproject.enrichers<span class="w"> </span>navegador<span class="w"> </span>enrich<span class="w"> </span>./src<span class="w"> </span>--framework<span class="w"> </span>celery
1857
</code></pre></div>
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
</article>
1872
</div>
1873
1874
1875
<script>var tabs=__md_get("__tabs");if(Array.isArray(tabs))e:for(var set of document.querySelectorAll(".tabbed-set")){var labels=set.querySelector(".tabbed-labels");for(var tab of tabs)for(var label of labels.getElementsByTagName("label"))if(label.innerText.trim()===tab){var input=document.getElementById(label.htmlFor);input.checked=!0;continue e}}</script>
1876
1877
<script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script>
1878
</div>
1879
1880
<button type="button" class="md-top md-icon" data-md-component="top" hidden>
1881
1882
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M13 20h-2V8l-5.5 5.5-1.42-1.42L12 4.16l7.92 7.92-1.42 1.42L13 8z"/></svg>
1883
Back to top
1884
</button>
1885
1886
</main>
1887
1888
<footer class="md-footer">
1889
1890
<div class="md-footer-meta md-typeset">
1891
<div class="md-footer-meta__inner md-grid">
1892
<div class="md-copyright">
1893
1894
<div class="md-copyright__highlight">
1895
Copyright &copy; 2026 CONFLICT LLC
1896
</div>
1897
1898
1899
Made with
1900
<a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
1901
Material for MkDocs
1902
</a>
1903
1904
</div>
1905
1906
1907
<div class="md-social">
1908
1909
1910
1911
1912
1913
1914
1915
1916
<a href="https://github.com/ConflictHQ/navegador" target="_blank" rel="noopener" title="github.com" class="md-social__link">
1917
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M173.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6m-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3m44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9M252.8 8C114.1 8 8 113.3 8 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C436.2 457.8 504 362.9 504 252 504 113.3 391.5 8 252.8 8M105.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1m-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7m32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1m-11.4-14.7c-1.6 1-1.6 3.6 0 5.9s4.3 3.3 5.6 2.3c1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2"/></svg>
1918
</a>
1919
1920
</div>
1921
1922
</div>
1923
</div>
1924
</footer>
1925
1926
</div>
1927
<div class="md-dialog" data-md-component="dialog">
1928
<div class="md-dialog__inner md-typeset"></div>
1929
</div>
1930
1931
1932
1933
1934
1935
<script id="__config" type="application/json">{"annotate": null, "base": "../..", "features": ["navigation.instant", "navigation.tabs", "navigation.sections", "navigation.expand", "navigation.top", "search.suggest", "search.highlight", "content.code.copy", "content.tabs.link", "header.autohide"], "search": "../../assets/javascripts/workers/search.2c215733.min.js", "tags": null, "translations": {"clipboard.copied": "Copied to clipboard", "clipboard.copy": "Copy to clipboard", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.placeholder": "Type to start searching", "search.result.term.missing": "Missing", "select.version": "Select version"}, "version": null}</script>
1936
1937
1938
<script src="../../assets/javascripts/bundle.79ae519e.min.js"></script>
1939
1940
1941
</body>
1942
</html>

Keyboard Shortcuts

Open search /
Next entry (timeline) j
Previous entry (timeline) k
Open focused entry Enter
Show this help ?
Toggle theme Top nav button