Navegador

navegador / guide / agent-hooks / index.html
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/agent-hooks/">
16
17
18
<link rel="prev" href="../cluster/">
19
20
21
<link rel="next" href="../planopticon/">
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>Agent Hooks - 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="#agent-hooks" 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
Agent Hooks
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
<li class="md-nav__item">
664
<a href="../framework-enrichment/" class="md-nav__link">
665
666
667
668
<span class="md-ellipsis">
669
670
671
Framework Enrichment
672
673
674
675
</span>
676
677
678
679
</a>
680
</li>
681
682
683
684
685
686
687
688
689
690
691
<li class="md-nav__item">
692
<a href="../analysis/" class="md-nav__link">
693
694
695
696
<span class="md-ellipsis">
697
698
699
Structural Analysis
700
701
702
703
</span>
704
705
706
707
</a>
708
</li>
709
710
711
712
713
714
715
716
717
718
719
<li class="md-nav__item">
720
<a href="../intelligence/" class="md-nav__link">
721
722
723
724
<span class="md-ellipsis">
725
726
727
Intelligence Layer
728
729
730
731
</span>
732
733
734
735
</a>
736
</li>
737
738
739
740
741
742
743
744
745
746
747
<li class="md-nav__item">
748
<a href="../sdk/" class="md-nav__link">
749
750
751
752
<span class="md-ellipsis">
753
754
755
Python SDK
756
757
758
759
</span>
760
761
762
763
</a>
764
</li>
765
766
767
768
769
770
771
772
773
774
775
<li class="md-nav__item">
776
<a href="../graph-queries/" class="md-nav__link">
777
778
779
780
<span class="md-ellipsis">
781
782
783
Graph Queries
784
785
786
787
</span>
788
789
790
791
</a>
792
</li>
793
794
795
796
797
798
799
800
801
802
803
<li class="md-nav__item">
804
<a href="../mcp-integration/" class="md-nav__link">
805
806
807
808
<span class="md-ellipsis">
809
810
811
MCP Integration
812
813
814
815
</span>
816
817
818
819
</a>
820
</li>
821
822
823
824
825
826
827
828
829
830
831
<li class="md-nav__item">
832
<a href="../ci-cd/" class="md-nav__link">
833
834
835
836
<span class="md-ellipsis">
837
838
839
CI/CD
840
841
842
843
</span>
844
845
846
847
</a>
848
</li>
849
850
851
852
853
854
855
856
857
858
859
<li class="md-nav__item">
860
<a href="../cluster/" class="md-nav__link">
861
862
863
864
<span class="md-ellipsis">
865
866
867
Cluster Mode
868
869
870
871
</span>
872
873
874
875
</a>
876
</li>
877
878
879
880
881
882
883
884
885
886
887
888
889
<li class="md-nav__item md-nav__item--active">
890
891
<input class="md-nav__toggle md-toggle" type="checkbox" id="__toc">
892
893
894
895
896
897
<label class="md-nav__link md-nav__link--active" for="__toc">
898
899
900
901
<span class="md-ellipsis">
902
903
904
Agent Hooks
905
906
907
908
</span>
909
910
911
912
<span class="md-nav__icon md-icon"></span>
913
</label>
914
915
<a href="./" class="md-nav__link md-nav__link--active">
916
917
918
919
<span class="md-ellipsis">
920
921
922
Agent Hooks
923
924
925
926
</span>
927
928
929
930
</a>
931
932
933
934
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
935
936
937
938
939
940
941
<label class="md-nav__title" for="__toc">
942
<span class="md-nav__icon md-icon"></span>
943
Table of contents
944
</label>
945
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
946
947
<li class="md-nav__item">
948
<a href="#why-hooks" class="md-nav__link">
949
<span class="md-ellipsis">
950
951
Why hooks
952
953
</span>
954
</a>
955
956
</li>
957
958
<li class="md-nav__item">
959
<a href="#claude-code" class="md-nav__link">
960
<span class="md-ellipsis">
961
962
Claude Code
963
964
</span>
965
</a>
966
967
<nav class="md-nav" aria-label="Claude Code">
968
<ul class="md-nav__list">
969
970
<li class="md-nav__item">
971
<a href="#install" class="md-nav__link">
972
<span class="md-ellipsis">
973
974
Install
975
976
</span>
977
</a>
978
979
</li>
980
981
<li class="md-nav__item">
982
<a href="#settingsjson-config" class="md-nav__link">
983
<span class="md-ellipsis">
984
985
settings.json config
986
987
</span>
988
</a>
989
990
</li>
991
992
<li class="md-nav__item">
993
<a href="#what-the-hook-does" class="md-nav__link">
994
<span class="md-ellipsis">
995
996
What the hook does
997
998
</span>
999
</a>
1000
1001
</li>
1002
1003
</ul>
1004
</nav>
1005
1006
</li>
1007
1008
<li class="md-nav__item">
1009
<a href="#gemini-cli" class="md-nav__link">
1010
<span class="md-ellipsis">
1011
1012
Gemini CLI
1013
1014
</span>
1015
</a>
1016
1017
<nav class="md-nav" aria-label="Gemini CLI">
1018
<ul class="md-nav__list">
1019
1020
<li class="md-nav__item">
1021
<a href="#install_1" class="md-nav__link">
1022
<span class="md-ellipsis">
1023
1024
Install
1025
1026
</span>
1027
</a>
1028
1029
</li>
1030
1031
<li class="md-nav__item">
1032
<a href="#geminimd-config" class="md-nav__link">
1033
<span class="md-ellipsis">
1034
1035
GEMINI.md config
1036
1037
</span>
1038
</a>
1039
1040
</li>
1041
1042
</ul>
1043
</nav>
1044
1045
</li>
1046
1047
<li class="md-nav__item">
1048
<a href="#openai" class="md-nav__link">
1049
<span class="md-ellipsis">
1050
1051
OpenAI
1052
1053
</span>
1054
</a>
1055
1056
<nav class="md-nav" aria-label="OpenAI">
1057
<ul class="md-nav__list">
1058
1059
<li class="md-nav__item">
1060
<a href="#install_2" class="md-nav__link">
1061
<span class="md-ellipsis">
1062
1063
Install
1064
1065
</span>
1066
</a>
1067
1068
</li>
1069
1070
<li class="md-nav__item">
1071
<a href="#openai-toolsjson" class="md-nav__link">
1072
<span class="md-ellipsis">
1073
1074
openai-tools.json
1075
1076
</span>
1077
</a>
1078
1079
</li>
1080
1081
<li class="md-nav__item">
1082
<a href="#dispatcher-script" class="md-nav__link">
1083
<span class="md-ellipsis">
1084
1085
Dispatcher script
1086
1087
</span>
1088
</a>
1089
1090
</li>
1091
1092
</ul>
1093
</nav>
1094
1095
</li>
1096
1097
<li class="md-nav__item">
1098
<a href="#navegadormd-template" class="md-nav__link">
1099
<span class="md-ellipsis">
1100
1101
NAVEGADOR.md template
1102
1103
</span>
1104
</a>
1105
1106
</li>
1107
1108
<li class="md-nav__item">
1109
<a href="#before-adding-new-patterns" class="md-nav__link">
1110
<span class="md-ellipsis">
1111
1112
Before adding new patterns
1113
1114
</span>
1115
</a>
1116
1117
</li>
1118
1119
<li class="md-nav__item">
1120
<a href="#after-editing-code" class="md-nav__link">
1121
<span class="md-ellipsis">
1122
1123
After editing code
1124
1125
</span>
1126
</a>
1127
1128
</li>
1129
1130
<li class="md-nav__item">
1131
<a href="#key-domains" class="md-nav__link">
1132
<span class="md-ellipsis">
1133
1134
Key domains
1135
1136
</span>
1137
</a>
1138
1139
</li>
1140
1141
</ul>
1142
1143
</nav>
1144
1145
</li>
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
<li class="md-nav__item">
1157
<a href="../planopticon/" class="md-nav__link">
1158
1159
1160
1161
<span class="md-ellipsis">
1162
1163
1164
Planopticon
1165
1166
1167
1168
</span>
1169
1170
1171
1172
</a>
1173
</li>
1174
1175
1176
1177
1178
</ul>
1179
</nav>
1180
1181
</li>
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
<li class="md-nav__item md-nav__item--nested">
1202
1203
1204
1205
1206
1207
<input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_4" >
1208
1209
1210
<label class="md-nav__link" for="__nav_4" id="__nav_4_label" tabindex="0">
1211
1212
1213
1214
<span class="md-ellipsis">
1215
1216
1217
Architecture
1218
1219
1220
1221
</span>
1222
1223
1224
1225
<span class="md-nav__icon md-icon"></span>
1226
</label>
1227
1228
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_4_label" aria-expanded="false">
1229
<label class="md-nav__title" for="__nav_4">
1230
<span class="md-nav__icon md-icon"></span>
1231
1232
1233
Architecture
1234
1235
1236
</label>
1237
<ul class="md-nav__list" data-md-scrollfix>
1238
1239
1240
1241
1242
1243
1244
1245
<li class="md-nav__item">
1246
<a href="../../architecture/overview/" class="md-nav__link">
1247
1248
1249
1250
<span class="md-ellipsis">
1251
1252
1253
Overview
1254
1255
1256
1257
</span>
1258
1259
1260
1261
</a>
1262
</li>
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
<li class="md-nav__item">
1274
<a href="../../architecture/graph-schema/" class="md-nav__link">
1275
1276
1277
1278
<span class="md-ellipsis">
1279
1280
1281
Graph Schema
1282
1283
1284
1285
</span>
1286
1287
1288
1289
</a>
1290
</li>
1291
1292
1293
1294
1295
</ul>
1296
</nav>
1297
1298
</li>
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
<li class="md-nav__item md-nav__item--nested">
1319
1320
1321
1322
1323
1324
<input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_5" >
1325
1326
1327
<label class="md-nav__link" for="__nav_5" id="__nav_5_label" tabindex="0">
1328
1329
1330
1331
<span class="md-ellipsis">
1332
1333
1334
API Reference
1335
1336
1337
1338
</span>
1339
1340
1341
1342
<span class="md-nav__icon md-icon"></span>
1343
</label>
1344
1345
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_5_label" aria-expanded="false">
1346
<label class="md-nav__title" for="__nav_5">
1347
<span class="md-nav__icon md-icon"></span>
1348
1349
1350
API Reference
1351
1352
1353
</label>
1354
<ul class="md-nav__list" data-md-scrollfix>
1355
1356
1357
1358
1359
1360
1361
1362
<li class="md-nav__item">
1363
<a href="../../api/sdk/" class="md-nav__link">
1364
1365
1366
1367
<span class="md-ellipsis">
1368
1369
1370
Python SDK
1371
1372
1373
1374
</span>
1375
1376
1377
1378
</a>
1379
</li>
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
<li class="md-nav__item">
1391
<a href="../../api/ingestion/" class="md-nav__link">
1392
1393
1394
1395
<span class="md-ellipsis">
1396
1397
1398
Ingestion
1399
1400
1401
1402
</span>
1403
1404
1405
1406
</a>
1407
</li>
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
<li class="md-nav__item">
1419
<a href="../../api/analysis/" class="md-nav__link">
1420
1421
1422
1423
<span class="md-ellipsis">
1424
1425
1426
Analysis
1427
1428
1429
1430
</span>
1431
1432
1433
1434
</a>
1435
</li>
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
<li class="md-nav__item">
1447
<a href="../../api/graph/" class="md-nav__link">
1448
1449
1450
1451
<span class="md-ellipsis">
1452
1453
1454
Graph
1455
1456
1457
1458
</span>
1459
1460
1461
1462
</a>
1463
</li>
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
<li class="md-nav__item">
1475
<a href="../../api/mcp/" class="md-nav__link">
1476
1477
1478
1479
<span class="md-ellipsis">
1480
1481
1482
MCP Server
1483
1484
1485
1486
</span>
1487
1488
1489
1490
</a>
1491
</li>
1492
1493
1494
1495
1496
</ul>
1497
</nav>
1498
1499
</li>
1500
1501
1502
1503
</ul>
1504
</nav>
1505
</div>
1506
</div>
1507
</div>
1508
1509
1510
1511
<div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
1512
<div class="md-sidebar__scrollwrap">
1513
<div class="md-sidebar__inner">
1514
1515
1516
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
1517
1518
1519
1520
1521
1522
1523
<label class="md-nav__title" for="__toc">
1524
<span class="md-nav__icon md-icon"></span>
1525
Table of contents
1526
</label>
1527
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
1528
1529
<li class="md-nav__item">
1530
<a href="#why-hooks" class="md-nav__link">
1531
<span class="md-ellipsis">
1532
1533
Why hooks
1534
1535
</span>
1536
</a>
1537
1538
</li>
1539
1540
<li class="md-nav__item">
1541
<a href="#claude-code" class="md-nav__link">
1542
<span class="md-ellipsis">
1543
1544
Claude Code
1545
1546
</span>
1547
</a>
1548
1549
<nav class="md-nav" aria-label="Claude Code">
1550
<ul class="md-nav__list">
1551
1552
<li class="md-nav__item">
1553
<a href="#install" class="md-nav__link">
1554
<span class="md-ellipsis">
1555
1556
Install
1557
1558
</span>
1559
</a>
1560
1561
</li>
1562
1563
<li class="md-nav__item">
1564
<a href="#settingsjson-config" class="md-nav__link">
1565
<span class="md-ellipsis">
1566
1567
settings.json config
1568
1569
</span>
1570
</a>
1571
1572
</li>
1573
1574
<li class="md-nav__item">
1575
<a href="#what-the-hook-does" class="md-nav__link">
1576
<span class="md-ellipsis">
1577
1578
What the hook does
1579
1580
</span>
1581
</a>
1582
1583
</li>
1584
1585
</ul>
1586
</nav>
1587
1588
</li>
1589
1590
<li class="md-nav__item">
1591
<a href="#gemini-cli" class="md-nav__link">
1592
<span class="md-ellipsis">
1593
1594
Gemini CLI
1595
1596
</span>
1597
</a>
1598
1599
<nav class="md-nav" aria-label="Gemini CLI">
1600
<ul class="md-nav__list">
1601
1602
<li class="md-nav__item">
1603
<a href="#install_1" class="md-nav__link">
1604
<span class="md-ellipsis">
1605
1606
Install
1607
1608
</span>
1609
</a>
1610
1611
</li>
1612
1613
<li class="md-nav__item">
1614
<a href="#geminimd-config" class="md-nav__link">
1615
<span class="md-ellipsis">
1616
1617
GEMINI.md config
1618
1619
</span>
1620
</a>
1621
1622
</li>
1623
1624
</ul>
1625
</nav>
1626
1627
</li>
1628
1629
<li class="md-nav__item">
1630
<a href="#openai" class="md-nav__link">
1631
<span class="md-ellipsis">
1632
1633
OpenAI
1634
1635
</span>
1636
</a>
1637
1638
<nav class="md-nav" aria-label="OpenAI">
1639
<ul class="md-nav__list">
1640
1641
<li class="md-nav__item">
1642
<a href="#install_2" class="md-nav__link">
1643
<span class="md-ellipsis">
1644
1645
Install
1646
1647
</span>
1648
</a>
1649
1650
</li>
1651
1652
<li class="md-nav__item">
1653
<a href="#openai-toolsjson" class="md-nav__link">
1654
<span class="md-ellipsis">
1655
1656
openai-tools.json
1657
1658
</span>
1659
</a>
1660
1661
</li>
1662
1663
<li class="md-nav__item">
1664
<a href="#dispatcher-script" class="md-nav__link">
1665
<span class="md-ellipsis">
1666
1667
Dispatcher script
1668
1669
</span>
1670
</a>
1671
1672
</li>
1673
1674
</ul>
1675
</nav>
1676
1677
</li>
1678
1679
<li class="md-nav__item">
1680
<a href="#navegadormd-template" class="md-nav__link">
1681
<span class="md-ellipsis">
1682
1683
NAVEGADOR.md template
1684
1685
</span>
1686
</a>
1687
1688
</li>
1689
1690
<li class="md-nav__item">
1691
<a href="#before-adding-new-patterns" class="md-nav__link">
1692
<span class="md-ellipsis">
1693
1694
Before adding new patterns
1695
1696
</span>
1697
</a>
1698
1699
</li>
1700
1701
<li class="md-nav__item">
1702
<a href="#after-editing-code" class="md-nav__link">
1703
<span class="md-ellipsis">
1704
1705
After editing code
1706
1707
</span>
1708
</a>
1709
1710
</li>
1711
1712
<li class="md-nav__item">
1713
<a href="#key-domains" class="md-nav__link">
1714
<span class="md-ellipsis">
1715
1716
Key domains
1717
1718
</span>
1719
</a>
1720
1721
</li>
1722
1723
</ul>
1724
1725
</nav>
1726
</div>
1727
</div>
1728
</div>
1729
1730
1731
1732
<div class="md-content" data-md-component="content">
1733
1734
<article class="md-content__inner md-typeset">
1735
1736
1737
1738
1739
1740
1741
1742
1743
<h1 id="agent-hooks">Agent Hooks<a class="headerlink" href="#agent-hooks" title="Permanent link">&para;</a></h1>
1744
<p>Agent hooks keep the navegador graph in sync as AI coding agents work. Without hooks, the graph goes stale the moment an agent edits a file. With hooks, the graph is re-ingested automatically after every file write, and architectural decisions in <code>DECISIONS.md</code> are synced into the knowledge layer.</p>
1745
<hr />
1746
<h2 id="why-hooks">Why hooks<a class="headerlink" href="#why-hooks" title="Permanent link">&para;</a></h2>
1747
<p>A stale graph gives wrong answers. If an agent adds a new function and then asks <code>navegador function</code> about a caller, the graph needs to reflect the edit. Hooks solve this by triggering <code>navegador ingest</code> on the modified files immediately after the agent writes them.</p>
1748
<p>Hooks also enforce the habit: every agent session starts with the graph as ground truth, not a stale snapshot.</p>
1749
<hr />
1750
<h2 id="claude-code">Claude Code<a class="headerlink" href="#claude-code" title="Permanent link">&para;</a></h2>
1751
<h3 id="install">Install<a class="headerlink" href="#install" title="Permanent link">&para;</a></h3>
1752
<p>The hook file lives at <code>.claude/hooks/claude-hook.py</code>. Bootstrap installs it automatically:</p>
1753
<div class="highlight"><pre><span></span><code><a id="__codelineno-0-1" name="__codelineno-0-1" href="#__codelineno-0-1"></a>./bootstrap.sh<span class="w"> </span>--repo<span class="w"> </span>owner/repo<span class="w"> </span>--agent<span class="w"> </span>claude
1754
</code></pre></div>
1755
<p>To install manually, copy <code>hooks/claude-hook.py</code> from the navegador repo into your project's <code>.claude/hooks/</code> directory.</p>
1756
<h3 id="settingsjson-config">settings.json config<a class="headerlink" href="#settingsjson-config" title="Permanent link">&para;</a></h3>
1757
<p>In your project's <code>.claude/settings.json</code>, register the hook:</p>
1758
<div class="highlight"><pre><span></span><code><a id="__codelineno-1-1" name="__codelineno-1-1" href="#__codelineno-1-1"></a><span class="p">{</span>
1759
<a id="__codelineno-1-2" name="__codelineno-1-2" href="#__codelineno-1-2"></a><span class="w"> </span><span class="nt">&quot;hooks&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span>
1760
<a id="__codelineno-1-3" name="__codelineno-1-3" href="#__codelineno-1-3"></a><span class="w"> </span><span class="nt">&quot;PostToolUse&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">[</span>
1761
<a id="__codelineno-1-4" name="__codelineno-1-4" href="#__codelineno-1-4"></a><span class="w"> </span><span class="p">{</span>
1762
<a id="__codelineno-1-5" name="__codelineno-1-5" href="#__codelineno-1-5"></a><span class="w"> </span><span class="nt">&quot;matcher&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;Write|Edit|MultiEdit&quot;</span><span class="p">,</span>
1763
<a id="__codelineno-1-6" name="__codelineno-1-6" href="#__codelineno-1-6"></a><span class="w"> </span><span class="nt">&quot;hooks&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">[</span>
1764
<a id="__codelineno-1-7" name="__codelineno-1-7" href="#__codelineno-1-7"></a><span class="w"> </span><span class="p">{</span>
1765
<a id="__codelineno-1-8" name="__codelineno-1-8" href="#__codelineno-1-8"></a><span class="w"> </span><span class="nt">&quot;type&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;command&quot;</span><span class="p">,</span>
1766
<a id="__codelineno-1-9" name="__codelineno-1-9" href="#__codelineno-1-9"></a><span class="w"> </span><span class="nt">&quot;command&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;python .claude/hooks/claude-hook.py&quot;</span>
1767
<a id="__codelineno-1-10" name="__codelineno-1-10" href="#__codelineno-1-10"></a><span class="w"> </span><span class="p">}</span>
1768
<a id="__codelineno-1-11" name="__codelineno-1-11" href="#__codelineno-1-11"></a><span class="w"> </span><span class="p">]</span>
1769
<a id="__codelineno-1-12" name="__codelineno-1-12" href="#__codelineno-1-12"></a><span class="w"> </span><span class="p">}</span>
1770
<a id="__codelineno-1-13" name="__codelineno-1-13" href="#__codelineno-1-13"></a><span class="w"> </span><span class="p">]</span>
1771
<a id="__codelineno-1-14" name="__codelineno-1-14" href="#__codelineno-1-14"></a><span class="w"> </span><span class="p">}</span>
1772
<a id="__codelineno-1-15" name="__codelineno-1-15" href="#__codelineno-1-15"></a><span class="p">}</span>
1773
</code></pre></div>
1774
<h3 id="what-the-hook-does">What the hook does<a class="headerlink" href="#what-the-hook-does" title="Permanent link">&para;</a></h3>
1775
<p>On every <code>Write</code>, <code>Edit</code>, or <code>MultiEdit</code> tool call:</p>
1776
<ol>
1777
<li>Reads the list of modified file paths from the tool result</li>
1778
<li>Runs <code>navegador ingest</code> scoped to those files (fast incremental update)</li>
1779
<li>Checks for changes to <code>DECISIONS.md</code> — if found, syncs any new ADR entries into the graph as <code>Decision</code> nodes</li>
1780
<li>Logs a one-line summary to stderr (visible in Claude's tool output)</li>
1781
</ol>
1782
<hr />
1783
<h2 id="gemini-cli">Gemini CLI<a class="headerlink" href="#gemini-cli" title="Permanent link">&para;</a></h2>
1784
<h3 id="install_1">Install<a class="headerlink" href="#install_1" title="Permanent link">&para;</a></h3>
1785
<p>The hook file lives at <code>.gemini/hooks/gemini-hook.py</code>. Bootstrap installs it automatically:</p>
1786
<div class="highlight"><pre><span></span><code><a id="__codelineno-2-1" name="__codelineno-2-1" href="#__codelineno-2-1"></a>./bootstrap.sh<span class="w"> </span>--repo<span class="w"> </span>owner/repo<span class="w"> </span>--agent<span class="w"> </span>gemini
1787
</code></pre></div>
1788
<p>To install manually, copy <code>hooks/gemini-hook.py</code> from the navegador repo into your project's <code>.gemini/hooks/</code> directory.</p>
1789
<h3 id="geminimd-config">GEMINI.md config<a class="headerlink" href="#geminimd-config" title="Permanent link">&para;</a></h3>
1790
<p>Add to your project's <code>GEMINI.md</code>:</p>
1791
<p><div class="highlight"><pre><span></span><code><a id="__codelineno-3-1" name="__codelineno-3-1" href="#__codelineno-3-1"></a><span class="gu">## Tool Hooks</span>
1792
<a id="__codelineno-3-2" name="__codelineno-3-2" href="#__codelineno-3-2"></a>
1793
<a id="__codelineno-3-3" name="__codelineno-3-3" href="#__codelineno-3-3"></a>After writing or editing any source file, run:
1794
</code></pre></div>
1795
python .gemini/hooks/gemini-hook.py <file_path>
1796
<div class="highlight"><pre><span></span><code><a id="__codelineno-4-1" name="__codelineno-4-1" href="#__codelineno-4-1"></a>This keeps the navegador knowledge graph in sync. The graph is your source of truth for code structure and project decisions.
1797
</code></pre></div></p>
1798
<p>The Gemini CLI does not have a declarative hook registry like Claude. The <code>GEMINI.md</code> instruction tells the model to call the hook script explicitly as a tool after file writes.</p>
1799
<hr />
1800
<h2 id="openai">OpenAI<a class="headerlink" href="#openai" title="Permanent link">&para;</a></h2>
1801
<p>OpenAI agents use a dispatcher script and a tool definition JSON file.</p>
1802
<h3 id="install_2">Install<a class="headerlink" href="#install_2" title="Permanent link">&para;</a></h3>
1803
<div class="highlight"><pre><span></span><code><a id="__codelineno-5-1" name="__codelineno-5-1" href="#__codelineno-5-1"></a>./bootstrap.sh<span class="w"> </span>--repo<span class="w"> </span>owner/repo<span class="w"> </span>--agent<span class="w"> </span>openai
1804
</code></pre></div>
1805
<p>This places:
1806
- <code>openai-hook.py</code> — dispatcher script
1807
- <code>openai-tools.json</code> — tool schema for the OpenAI function-calling API</p>
1808
<h3 id="openai-toolsjson">openai-tools.json<a class="headerlink" href="#openai-toolsjson" title="Permanent link">&para;</a></h3>
1809
<p>The tool schema exposes navegador commands as callable functions:</p>
1810
<div class="highlight"><pre><span></span><code><a id="__codelineno-6-1" name="__codelineno-6-1" href="#__codelineno-6-1"></a><span class="p">[</span>
1811
<a id="__codelineno-6-2" name="__codelineno-6-2" href="#__codelineno-6-2"></a><span class="w"> </span><span class="p">{</span>
1812
<a id="__codelineno-6-3" name="__codelineno-6-3" href="#__codelineno-6-3"></a><span class="w"> </span><span class="nt">&quot;type&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;function&quot;</span><span class="p">,</span>
1813
<a id="__codelineno-6-4" name="__codelineno-6-4" href="#__codelineno-6-4"></a><span class="w"> </span><span class="nt">&quot;function&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span>
1814
<a id="__codelineno-6-5" name="__codelineno-6-5" href="#__codelineno-6-5"></a><span class="w"> </span><span class="nt">&quot;name&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;navegador_explain&quot;</span><span class="p">,</span>
1815
<a id="__codelineno-6-6" name="__codelineno-6-6" href="#__codelineno-6-6"></a><span class="w"> </span><span class="nt">&quot;description&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;Look up any code or knowledge node by name&quot;</span><span class="p">,</span>
1816
<a id="__codelineno-6-7" name="__codelineno-6-7" href="#__codelineno-6-7"></a><span class="w"> </span><span class="nt">&quot;parameters&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span>
1817
<a id="__codelineno-6-8" name="__codelineno-6-8" href="#__codelineno-6-8"></a><span class="w"> </span><span class="nt">&quot;type&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;object&quot;</span><span class="p">,</span>
1818
<a id="__codelineno-6-9" name="__codelineno-6-9" href="#__codelineno-6-9"></a><span class="w"> </span><span class="nt">&quot;properties&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span>
1819
<a id="__codelineno-6-10" name="__codelineno-6-10" href="#__codelineno-6-10"></a><span class="w"> </span><span class="nt">&quot;name&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> </span><span class="nt">&quot;type&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;string&quot;</span><span class="p">,</span><span class="w"> </span><span class="nt">&quot;description&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;Node name to explain&quot;</span><span class="w"> </span><span class="p">},</span>
1820
<a id="__codelineno-6-11" name="__codelineno-6-11" href="#__codelineno-6-11"></a><span class="w"> </span><span class="nt">&quot;file&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> </span><span class="nt">&quot;type&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;string&quot;</span><span class="p">,</span><span class="w"> </span><span class="nt">&quot;description&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;Optional file path to disambiguate&quot;</span><span class="w"> </span><span class="p">}</span>
1821
<a id="__codelineno-6-12" name="__codelineno-6-12" href="#__codelineno-6-12"></a><span class="w"> </span><span class="p">},</span>
1822
<a id="__codelineno-6-13" name="__codelineno-6-13" href="#__codelineno-6-13"></a><span class="w"> </span><span class="nt">&quot;required&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">[</span><span class="s2">&quot;name&quot;</span><span class="p">]</span>
1823
<a id="__codelineno-6-14" name="__codelineno-6-14" href="#__codelineno-6-14"></a><span class="w"> </span><span class="p">}</span>
1824
<a id="__codelineno-6-15" name="__codelineno-6-15" href="#__codelineno-6-15"></a><span class="w"> </span><span class="p">}</span>
1825
<a id="__codelineno-6-16" name="__codelineno-6-16" href="#__codelineno-6-16"></a><span class="w"> </span><span class="p">},</span>
1826
<a id="__codelineno-6-17" name="__codelineno-6-17" href="#__codelineno-6-17"></a><span class="w"> </span><span class="p">{</span>
1827
<a id="__codelineno-6-18" name="__codelineno-6-18" href="#__codelineno-6-18"></a><span class="w"> </span><span class="nt">&quot;type&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;function&quot;</span><span class="p">,</span>
1828
<a id="__codelineno-6-19" name="__codelineno-6-19" href="#__codelineno-6-19"></a><span class="w"> </span><span class="nt">&quot;function&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span>
1829
<a id="__codelineno-6-20" name="__codelineno-6-20" href="#__codelineno-6-20"></a><span class="w"> </span><span class="nt">&quot;name&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;navegador_ingest&quot;</span><span class="p">,</span>
1830
<a id="__codelineno-6-21" name="__codelineno-6-21" href="#__codelineno-6-21"></a><span class="w"> </span><span class="nt">&quot;description&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;Re-ingest a file or directory into the knowledge graph&quot;</span><span class="p">,</span>
1831
<a id="__codelineno-6-22" name="__codelineno-6-22" href="#__codelineno-6-22"></a><span class="w"> </span><span class="nt">&quot;parameters&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span>
1832
<a id="__codelineno-6-23" name="__codelineno-6-23" href="#__codelineno-6-23"></a><span class="w"> </span><span class="nt">&quot;type&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;object&quot;</span><span class="p">,</span>
1833
<a id="__codelineno-6-24" name="__codelineno-6-24" href="#__codelineno-6-24"></a><span class="w"> </span><span class="nt">&quot;properties&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span>
1834
<a id="__codelineno-6-25" name="__codelineno-6-25" href="#__codelineno-6-25"></a><span class="w"> </span><span class="nt">&quot;path&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">{</span><span class="w"> </span><span class="nt">&quot;type&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;string&quot;</span><span class="p">,</span><span class="w"> </span><span class="nt">&quot;description&quot;</span><span class="p">:</span><span class="w"> </span><span class="s2">&quot;File or directory path to ingest&quot;</span><span class="w"> </span><span class="p">}</span>
1835
<a id="__codelineno-6-26" name="__codelineno-6-26" href="#__codelineno-6-26"></a><span class="w"> </span><span class="p">},</span>
1836
<a id="__codelineno-6-27" name="__codelineno-6-27" href="#__codelineno-6-27"></a><span class="w"> </span><span class="nt">&quot;required&quot;</span><span class="p">:</span><span class="w"> </span><span class="p">[</span><span class="s2">&quot;path&quot;</span><span class="p">]</span>
1837
<a id="__codelineno-6-28" name="__codelineno-6-28" href="#__codelineno-6-28"></a><span class="w"> </span><span class="p">}</span>
1838
<a id="__codelineno-6-29" name="__codelineno-6-29" href="#__codelineno-6-29"></a><span class="w"> </span><span class="p">}</span>
1839
<a id="__codelineno-6-30" name="__codelineno-6-30" href="#__codelineno-6-30"></a><span class="w"> </span><span class="p">}</span>
1840
<a id="__codelineno-6-31" name="__codelineno-6-31" href="#__codelineno-6-31"></a><span class="p">]</span>
1841
</code></pre></div>
1842
<h3 id="dispatcher-script">Dispatcher script<a class="headerlink" href="#dispatcher-script" title="Permanent link">&para;</a></h3>
1843
<p><code>openai-hook.py</code> receives function call JSON on stdin and dispatches to <code>navegador</code> CLI commands:</p>
1844
<div class="highlight"><pre><span></span><code><a id="__codelineno-7-1" name="__codelineno-7-1" href="#__codelineno-7-1"></a><span class="c1"># openai-hook.py dispatches tool calls to the navegador CLI</span>
1845
<a id="__codelineno-7-2" name="__codelineno-7-2" href="#__codelineno-7-2"></a><span class="c1"># usage: echo &#39;{&quot;name&quot;: &quot;navegador_explain&quot;, &quot;arguments&quot;: {&quot;name&quot;: &quot;AuthService&quot;}}&#39; | python openai-hook.py</span>
1846
</code></pre></div>
1847
<p>Register <code>openai-tools.json</code> in your OpenAI assistant configuration and point function call handling at <code>openai-hook.py</code>.</p>
1848
<hr />
1849
<h2 id="navegadormd-template">NAVEGADOR.md template<a class="headerlink" href="#navegadormd-template" title="Permanent link">&para;</a></h2>
1850
<p>Drop a <code>NAVEGADOR.md</code> in your project root so agents know the graph exists and how to use it. Example template:</p>
1851
<div class="highlight"><pre><span></span><code><a id="__codelineno-8-1" name="__codelineno-8-1" href="#__codelineno-8-1"></a><span class="gh"># Navegador Knowledge Graph</span>
1852
<a id="__codelineno-8-2" name="__codelineno-8-2" href="#__codelineno-8-2"></a>
1853
<a id="__codelineno-8-3" name="__codelineno-8-3" href="#__codelineno-8-3"></a>This project has a navegador knowledge graph at <span class="sb">`.navegador/navegador.db`</span>.
1854
<a id="__codelineno-8-4" name="__codelineno-8-4" href="#__codelineno-8-4"></a>
1855
<a id="__codelineno-8-5" name="__codelineno-8-5" href="#__codelineno-8-5"></a><span class="gu">## Before editing code</span>
1856
<a id="__codelineno-8-6" name="__codelineno-8-6" href="#__codelineno-8-6"></a>
1857
<a id="__codelineno-8-7" name="__codelineno-8-7" href="#__codelineno-8-7"></a>Run the relevant context command first:
1858
<a id="__codelineno-8-8" name="__codelineno-8-8" href="#__codelineno-8-8"></a>
1859
<a id="__codelineno-8-9" name="__codelineno-8-9" href="#__codelineno-8-9"></a>```bash
1860
<a id="__codelineno-8-10" name="__codelineno-8-10" href="#__codelineno-8-10"></a>navegador context &lt;file&gt; # full file context
1861
<a id="__codelineno-8-11" name="__codelineno-8-11" href="#__codelineno-8-11"></a>navegador function &lt;name&gt; # function + call graph
1862
<a id="__codelineno-8-12" name="__codelineno-8-12" href="#__codelineno-8-12"></a>navegador class &lt;name&gt; # class + hierarchy
1863
<a id="__codelineno-8-13" name="__codelineno-8-13" href="#__codelineno-8-13"></a>navegador explain &lt;name&gt; # anything by name
1864
</code></pre></div>
1865
<h2 id="before-adding-new-patterns">Before adding new patterns<a class="headerlink" href="#before-adding-new-patterns" title="Permanent link">&para;</a></h2>
1866
<p>Check if a concept or rule already exists:</p>
1867
<div class="highlight"><pre><span></span><code><a id="__codelineno-9-1" name="__codelineno-9-1" href="#__codelineno-9-1"></a>navegador<span class="w"> </span>search<span class="w"> </span><span class="s2">&quot;&lt;topic&gt;&quot;</span><span class="w"> </span>--all
1868
<a id="__codelineno-9-2" name="__codelineno-9-2" href="#__codelineno-9-2"></a>navegador<span class="w"> </span>domain<span class="w"> </span>&lt;domain-name&gt;
1869
</code></pre></div>
1870
<h2 id="after-editing-code">After editing code<a class="headerlink" href="#after-editing-code" title="Permanent link">&para;</a></h2>
1871
<p>The agent hook re-ingests automatically. If you disabled hooks, run:</p>
1872
<div class="highlight"><pre><span></span><code><a id="__codelineno-10-1" name="__codelineno-10-1" href="#__codelineno-10-1"></a>navegador<span class="w"> </span>ingest<span class="w"> </span>./src<span class="w"> </span>--clear
1873
</code></pre></div>
1874
<h2 id="key-domains">Key domains<a class="headerlink" href="#key-domains" title="Permanent link">&para;</a></h2>
1875
<ul>
1876
<li><strong>Payments</strong> — payment processing, billing, idempotency rules</li>
1877
<li><strong>Auth</strong> — authentication, session management, permissions</li>
1878
<li><strong>Infrastructure</strong> — deployment, database, caching decisions
1879
<div class="highlight"><pre><span></span><code><a id="__codelineno-11-1" name="__codelineno-11-1" href="#__codelineno-11-1"></a>---
1880
<a id="__codelineno-11-2" name="__codelineno-11-2" href="#__codelineno-11-2"></a>
1881
<a id="__codelineno-11-3" name="__codelineno-11-3" href="#__codelineno-11-3"></a>## Bootstrap reference
1882
<a id="__codelineno-11-4" name="__codelineno-11-4" href="#__codelineno-11-4"></a>
1883
<a id="__codelineno-11-5" name="__codelineno-11-5" href="#__codelineno-11-5"></a>```bash
1884
<a id="__codelineno-11-6" name="__codelineno-11-6" href="#__codelineno-11-6"></a>./bootstrap.sh [options]
1885
</code></pre></div></li>
1886
</ul>
1887
<table>
1888
<thead>
1889
<tr>
1890
<th>Option</th>
1891
<th>Description</th>
1892
</tr>
1893
</thead>
1894
<tbody>
1895
<tr>
1896
<td><code>--repo owner/repo</code></td>
1897
<td>GitHub repo to clone and ingest</td>
1898
</tr>
1899
<tr>
1900
<td><code>--wiki</code></td>
1901
<td>Also ingest the GitHub wiki</td>
1902
</tr>
1903
<tr>
1904
<td><code>--agent claude</code></td>
1905
<td>Install Claude Code hook + settings.json config</td>
1906
</tr>
1907
<tr>
1908
<td><code>--agent gemini</code></td>
1909
<td>Install Gemini CLI hook + GEMINI.md instruction</td>
1910
</tr>
1911
<tr>
1912
<td><code>--agent openai</code></td>
1913
<td>Install openai-hook.py + openai-tools.json</td>
1914
</tr>
1915
<tr>
1916
<td><code>--db &lt;path&gt;</code></td>
1917
<td>Custom database path (default: <code>.navegador/navegador.db</code>)</td>
1918
</tr>
1919
</tbody>
1920
</table>
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
</article>
1935
</div>
1936
1937
1938
<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>
1939
1940
<script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script>
1941
</div>
1942
1943
<button type="button" class="md-top md-icon" data-md-component="top" hidden>
1944
1945
<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>
1946
Back to top
1947
</button>
1948
1949
</main>
1950
1951
<footer class="md-footer">
1952
1953
<div class="md-footer-meta md-typeset">
1954
<div class="md-footer-meta__inner md-grid">
1955
<div class="md-copyright">
1956
1957
<div class="md-copyright__highlight">
1958
Copyright &copy; 2026 CONFLICT LLC
1959
</div>
1960
1961
1962
Made with
1963
<a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
1964
Material for MkDocs
1965
</a>
1966
1967
</div>
1968
1969
1970
<div class="md-social">
1971
1972
1973
1974
1975
1976
1977
1978
1979
<a href="https://github.com/ConflictHQ/navegador" target="_blank" rel="noopener" title="github.com" class="md-social__link">
1980
<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>
1981
</a>
1982
1983
</div>
1984
1985
</div>
1986
</div>
1987
</footer>
1988
1989
</div>
1990
<div class="md-dialog" data-md-component="dialog">
1991
<div class="md-dialog__inner md-typeset"></div>
1992
</div>
1993
1994
1995
1996
1997
1998
<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>
1999
2000
2001
<script src="../../assets/javascripts/bundle.79ae519e.min.js"></script>
2002
2003
2004
</body>
2005
</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